browser.tabs 在 Firefox 扩展中未定义

vin*_*zee 9 javascript firefox firefox-addon

这是我的manifest.json文件:

{
  "manifest_version": 2,

  "permissions": ["tabs", "storage", "webRequest", "<all_urls>"],

  "content_scripts": [
    {
      "matches": ["<all_urls>"],
      "js": ["assets/js/jquery-3.3.1.min.js", "blocker.js"]
    }
  ],

  "background": {
    "scripts": ["background.js"]
  },

  "options_ui": {
    "page": "background-page.html",
    "browser_style": true
  }
}
Run Code Online (Sandbox Code Playgroud)

和我的blocker.js文件:

function cleanPage(tabId, changeInfo, tabInfo) {
  console.log("I am in cleanPage");
}

try {
  console.log("browser : ");
  console.log(browser);
  console.log("browser.tabs : " + browser.tabs);

  browser.tabs.onUpdated.addListener(cleanPage);

} catch(err) {
  console.log("err : ", err);
}
Run Code Online (Sandbox Code Playgroud)

我收到此错误:

browser.tabs : undefined blocker.js:114:3
err :  TypeError: "browser.tabs is undefined"
Run Code Online (Sandbox Code Playgroud)

我的设置:
- Mozilla Firefox 65.0.1
- Ubuntu 18.04

我不太明白这个错误,因为我正在按照Mozilla 教程中所写的进行操作。有谁知道为什么会出现这个错误?

vin*_*zee 13

我的blocker.js文件位于content_scripts. 我把它移到了background_scripts并且它起作用了。

只有来自 的文件background_scripts才能访问browser.tabsAPI。

我的新manifest.json文件:

{
  "manifest_version": 2,

  "permissions": ["tabs", "storage", "webRequest", "<all_urls>"],

  "content_scripts": [
    {
      "matches": ["<all_urls>"],
      "js": []
    }
  ],

  "background": {
    "scripts": ["assets/js/jquery-3.3.1.min.js", "background.js", "blocker.js"]
  },

  "options_ui": {
    "page": "background-page.html",
    "browser_style": true
  }
}
Run Code Online (Sandbox Code Playgroud)