2

我目前在bootstrap.js文件中使用它。在我使用的情况下,用于编辑客户端的 JavaScript 代码recentBrowserWindow.messageManager.loadFrameScript(file, true)

const {classes: Cc, interfaces: Ci, utils: Cu, results: Cr} = Components;
Cu.import('resource://gre/modules/Services.jsm');

var file = 'chrome://testAddon/content/inject.js';

function startup(aData, aReason) {
    var recentBrowserWindow = Services.wm.getMostRecentWindow('navigator:browser');
    if(recentBrowserWindow.document.readyState == 'complete') {
        recentBrowserWindow.messageManager.loadFrameScript(file, true);
    }
}

注入.js:

var window = content;
var pageJS = window.wrappedJSObject;
console.log("jQuery is defined:", "jQuery" in window);
//true, jQuery is already assigned on client page.

但是这里的脚本inject.js是在客户端页面之后运行的。问题是:

如何inject.js在页面的脚本执行之前注入?我应该使用什么方法?

4

2 回答 2

2

来自:https ://developer.mozilla.org/en-US/docs/Mozilla/Tech/XPCOM/Reference/Interface/nsIFrameScriptLoader

它说使用document-element-inserted,这将确保您的脚本在页面脚本运行之前运行。

我对框架脚本没有太多经验,其他人将不得不对此进行验证。

于 2015-06-29T23:36:48.193 回答
0

这是一个非常好的简单 loadFrameScript 示例:https ://github.com/mdn/e10s-example-addons/tree/master/run-script-in-all-pages/ported-message-manager/src/chrome/内容

在这里查看他如何处理 DOMContentLoaded:https ://github.com/mdn/e10s-example-addons/blob/master/run-script-in-all-pages/ported-message-manager/src/chrome/content/frame -script.js

将其更改为,document-element-inserted但我认为这不是事件侦听器,而是观察者服务。

于 2015-07-02T14:57:46.080 回答