12

这是我的 background.js 文件

 chrome.tabs.onUpdated.addListener(function(tabId,info, tab) {
    var sites =new Array('site2','site1');
    var url=tab.url;
    var siteFlag=0;
    for(var i in sites) {
       var regexp = new RegExp('.*' + sites[i] + '.*','i');
       if (regexp.test(url)) {siteFlag=1;}
    };
    if(siteFlag==1){
      chrome.tabs.executeScript(tabId, {file:"contentscript.js"});
      chrome.tabs.executeScript(tabId, {file:"jquery.js"});
      chrome.tabs.insertCSS(tabId,{file:"box.css"});
    }
 });

在 contentscript.js 中,我只是运行一个弹出框。

$(document).ready(function () {
    function popup() {...}
    if (window.addEventListener)
    {
        window.addEventListener('load', popup(), false); 
    } 
    else if (window.attachEvent)
    {
        window.attachEvent('onload', popup());
    }
});

有些页面只有一个弹出框,有些页面有两个甚至更多

问题是什么?

=============编辑===================

这些页面包含 iframe

4

4 回答 4

11

chrome.tabs.onUpdated.addListener当标签状态更改时,会触发,这与iframes无关。您的脚本被多次注入到同一帧,因为您为每次状态更改注入它,并且您只想在状态更改为“完成”时注入它。通过添加修改您的代码if (changeInfo.status == "complete") {

chrome.tabs.onUpdated.addListener(function(tabId,info, tab) {
   if (info.status == "complete") {
      /* checking & injecting stuff */
   }
});
于 2012-10-31T07:13:56.830 回答
9

我不确定为什么内容脚本会加载两次。但我也有这个问题。我将以下内容添加到 manifest.json 中的“content_scripts”元素中,效果很好。

"content_scripts" : [
    {
        "all_frames" : false,
        "run_at" : "document_end",
    }
]

最后,manifest.json:

{
    "name": "ABC",
    "version": "0.0.0.1",
    "manifest_version": 2,
    "key": "longkeyhere",
    "description": "Description",
    "minimum_chrome_version": "29",
    "background": {
        "scripts": [
            "jquery.js",
            "jquery.min.js",
        ]
    },
    "content_scripts" : [
        {
            "all_frames" : false,
            "run_at" : "document_end",
            "matches" : [ "http://*/*" ],
            "js" : [
                "jquery.js",
                "jquery.min.js",
            ]
        }
    ],
    "options_page": "options.html",
    "permissions": [
        "http://*/*",
        "https://*/*",
        "contextMenus",
        "tabs",
        "identity",
        "storage"
    ]
}
于 2014-11-15T23:00:48.673 回答
1

您可以使用扩展的清单文件控制内容脚本的执行:您可以阻止内容脚本加载到 iframe 或一组特定的 url。这是一个示例清单部分:

"all_frames": true,
 "js": [ "ContentOnDocStart.js" ],
 "matches": [ "http://*/*", "https://*/*" ],
 "exclude_matches": [ ],
 "run_at": "document_start"
于 2012-10-31T13:02:05.377 回答
1

这很可能是由使用框架的页面引起的。为每一帧加载脚本。如果您绝对想只执行一次脚本,您可能能够检测到您在哪一帧中加载,或者一帧是否已经有您的脚本。

于 2012-10-30T22:58:32.547 回答