首页 > 解决方案 > Mozilla 插件加载太晚而无法阻止资源

问题描述

我正在尝试取消从 studio.code.org 到 www.google.com/jsapi 的请求,以帮助加快页面加载速度。在我的语言环境中,谷歌被阻止,但浏览器等待 75 秒后放弃。我想通过阻止请求来防止延迟(并且页面似乎在没有 jsapi 的情况下工作正常)。

我按照https://developer.mozilla.org/en-US/docs/Mozilla/Add-ons/WebExtensions/API/webRequest/onBeforeRequest中的示例安装了插件。我包含了一个 console.log 语句来查看我的代码被调用,但它仅在浏览器等待另外 75 秒以尝试加载我希望阻止的资源后才显示。

如果这不起作用,我愿意接受其他方法。

清单.json:

{
  "manifest_version": 2,
  "name": "cancel-google",
  "version": "1.0",

  "permissions": [
    "webRequest",
    "webRequestBlocking"
  ],

  "content_scripts": [
    {
      "matches": ["https://studio.code.org/*"],
      "js": ["cancel-google.js"]     
    } 
  ]
}

取消-google.js:

// match pattern for the URLs to block
var pattern = "*www.google.com/jsapi";
console.log("cancelator script loaded");

// cancel function returns an object
// which contains a property `cancel` set to `true`
function cancel(requestDetails) {
  console.log("Cancelling: " + requestDetails.url);
  return {cancel: true};
}

// add the listener,
// passing the filter argument and "blocking"
browser.webRequest.onBeforeRequest.addListener(
  cancel,
  {urls: [pattern]},
  ["blocking"]
);

标签: requestfirefox-addonmozillafirefox-addon-webextensions

解决方案


cancel-google.js 应该作为后台脚本加载,对于大多数 WebExtension API 来说都是如此。

{
    "name": "Your Addon",
    "manifest_version": 2,
    "background": {
        "scripts": ["cancel-google.js"]
    }
}

然后它应该工作。


推荐阅读