我的清单如下所示:
{
"manifest_version": 2,
"name": "Facebook Extension",
"version": "1.0",
"browser_action": {
"default_icon": "images/fbh.png",
"default_popup": "fbh-popup.html"
},
"permissions": [
"storage",
"background",
"tabs",
"http://www.facebook.com/*",
"https://www.facebook.com/*"
],
"content_scripts": [
{
"matches": [
"http://www.facebook.com/*",
"https://www.facebook.com/*"
],
"js": ["js/jquery-1.9.1.min.js", "js/fbh-main.js"],
"css": ["css/fbh-main.css"],
"run_at": "document_end"
}
],
"background":{
"persistent": true,
"scripts": ["js/jquery-1.9.1.min.js","js/fbh-background.js"]
}
}
每次进入 Facebook 中的新页面时,我都想注入我的内容脚本。例如,如果我单击用户的个人资料,我想注入内容脚本。
在我的背景页面中,我有以下监听器:
chrome.tabs.onUpdated.addListener(function(tabId, changeInfo) {
console.log(changeInfo);
if (changeInfo.status === 'complete') {
chrome.tabs.executeScript(null, {file: "js/fbh-main.js"});
}
});
然而,这有几个问题。首先,此函数尝试将我的内容脚本注入所有页面。我需要能够读取清单权限。其次,如果我从 www.facebook.com 开始,内容脚本会做它应该做的事情。但是,如果从那里单击“foo”的配置文件并转到 www.facebook.com/foo,则会注入内容脚本(如 console.log 消息所证明的那样),但它没有做它应该做的事情. 我认为它被注入得太早了,因为如果我直接导航到 www.facebook.com/foo,内容脚本就会被加载并执行它的工作。
有一个更好的方法吗?