Javascript background.js内容脚本中的Chrome调用函数
我已经阅读了文档,但仍然无法使其正常工作 这是我的舱单:Javascript background.js内容脚本中的Chrome调用函数,javascript,google-chrome-extension,Javascript,Google Chrome Extension,我已经阅读了文档,但仍然无法使其正常工作 这是我的舱单: { "name":"app", "version":"0.1", "manifest_version":2, "description":"app", "background":{ "scripts":[ "scripts/modernizr.min.js", "scripts/background.js" ]
{
"name":"app",
"version":"0.1",
"manifest_version":2,
"description":"app",
"background":{
"scripts":[
"scripts/modernizr.min.js",
"scripts/background.js"
],
"persistent": false
},
"content_scripts": [
{
"matches": ["https://*/*", "http://*/*"],
"js": ["scripts/content.js"],
"run_at": "document_end"
}
],
"permissions":[
"contextMenus",
"tabs",
"http://*/*",
"https://*/*"
],
"icons":{
"16":"images/icon_16.png",
"128":"images/icon_128.png"
}
}
我在content.js中有一个名为“myFunc”的函数。在background.js中,我有一个函数“myHandler”,由contextMenus.onClicked侦听器调用。我想从myHandler调用myFunc。我尝试使用tabs.executeScript和tabs.query,但似乎无法调用该函数。有人能解释一下我应该如何让background.js调用content.js中的函数吗 要从后台页面调用内容脚本中的函数,首先需要知道选项卡id。
上下文菜单。一旦单击
事件,就会有一个包含该id的选项卡
参数。然后使用来执行此操作
例如,在您的背景页面中:
chrome.contextMenus.onClicked.addListener(function(info, tab) {
if (tab)
chrome.tabs.sendMessage(tab.id, {args: ...}, function(response) {
// ...
});
});
在内容脚本中:
chrome.runtime.onMessage.addListener(function(request, sender, sendResponse) {
sendResponse(myFunc(request.args));
});
我想补充一点,这个API在过去两年中一直在变化,这就是它现在的样子。@vittore啊,这也许可以解释为什么我所尝试的不起作用。