chrome.tabs.executeScript:如何从后台脚本中的内容脚本访问变量?

Max*_*lev 6 javascript google-chrome-extension

如何appapp.js后台脚本中的内容脚本访问变量background.js

这是我尝试它的方式(background.js):

chrome.tabs.executeScript(null, { file: "app.js" }, function() {
   app.getSettings('authorizeInProgress'); //...
});
Run Code Online (Sandbox Code Playgroud)

这是我得到的: tabs.executeScript期间出错:无法访问网址

这是manifest.json:

{
  "name": "ctrl-vk",
  "version": "0.1.3",
  "manifest_version": 2,
  "description": "Chrome extension for ctrl+v insertion of images to vk.com",

  "content_scripts": [{
    "matches": [
        "http://*/*",
        "https://*/*"
    ],
    "js": ["jquery-1.9.1.min.js"
    ],
    "run_at": "document_end"
  }],

  "web_accessible_resources": [
    "jquery-1.9.1.min.js"
  ],

  "permissions" : [
    "tabs",
    "http://*/*",
    "https://*/*"
  ],

  "background": {
    "persistent": false,
    "scripts": ["background.js"]
  }
}
Run Code Online (Sandbox Code Playgroud)

完整代码,例如,在github上

https://github.com/MaxLord/ctrl-vk/tree/with_bug

Sud*_*han 2

为了避免上述错误,请使用以下代码

if (tab.url.indexOf("chrome-devtools://") == -1) {
    chrome.tabs.executeScript(tabId, {
        file: "app.js"
    }, function () {

        if (app.getSettings('authorizeInProgress')) {
            alert('my tab');
            REDIRECT_URI = app.getSettings('REDIRECT_URI');
            if (tab.url.indexOf(REDIRECT_URI + "#access_token") >= 0) {
                app.setSettings('authorize_in_progress', false);
                chrome.tabs.remove(tabId);
                return app.finishAuthorize(tab.url);
            }
        } else {
            alert('not my');
        }

    });
}
Run Code Online (Sandbox Code Playgroud)

代替

chrome.tabs.executeScript(null, {
    file: "app.js"
}, function () {

    if (app.getSettings('authorizeInProgress')) {
        alert('my tab');
        REDIRECT_URI = app.getSettings('REDIRECT_URI');
        if (tab.url.indexOf(REDIRECT_URI + "#access_token") >= 0) {
            app.setSettings('authorize_in_progress', false);
            chrome.tabs.remove(tabId);
            return app.finishAuthorize(tab.url);
        }
    } else {
        alert('not my');
    }

});
Run Code Online (Sandbox Code Playgroud)

解释

  • chrome://extensions/页面也会触发chrome.tabs.onUpdated事件,为了避免它,我们必须添加一个过滤器来跳过所有开发工具页面。

  • 您必须使用消息传递或从“executeScript()”函数返回数组值来解析内容脚本的值。 (2认同)