【发布时间】:2017-05-16 02:33:47
【问题描述】:
我正在编写一个 Chrome 扩展程序来捕获用户文本选择并将所选文本发送到 Google 搜索。
manifest.json
{
"manifest_version": 2,
"name": "Selection Extension",
"description": "Search your selected text",
"version": "1.0",
"permissions": [
"tabs",
"http://*/*",
"https://*/*"
],
"background": {
"scripts": [
"background.js"
],
"persistent": false
},
"browser_action": {
"default_icon": "icon.png",
"default_title": "Mark it!!"
},
"content_scripts": [
{
"matches": ["<all_urls>"],
"js": ["content_script.js"]
}
]
content_script.js
chrome.extension.onMessage.addListener(function(request, sender, sendResponse) {
if (request.method == "getSelection") {
sendResponse({data: window.getSelection().toString()});
} else {
sendResponse({});
}
});
background.js
function initBackground() {
chrome.browserAction.onClicked.addListener(function(tab) {
chrome.tabs.sendMessage(tab.id, {method: "getSelection"}, function(response){
sendServiceRequest(response.data);
});
});
}
function sendServiceRequest(selectedText) {
var serviceCall = 'http://www.google.com/search?q=' + selectedText;
chrome.tabs.create({url: serviceCall});
}
initBackground();
此代码适用于网页(例如 Gmail、Facebook、新闻)中的选择。
我还希望能够在 PDF 和 Google Docs(在浏览器中查看)中获得选择。
在这些情况下:window.getSelection 返回一个空字符串...
有人知道怎么做吗?
【问题讨论】:
-
谢谢你!我将删除 executeScript。
-
对于 google-docs,有一个带有“kix-selection-overlay”类的 HTML 元素。此类是创建选择外观(即青色背景)的实际 div。但它无论如何都没有连接到包含文本的 div...
-
@Makyen 在这种情况下最小、完整和可验证的例子是唯一的
window.getSelection().toString()。 -
This video tutorial 几乎完全符合您的要求。
标签: javascript google-chrome-extension google-docs textselection