Firefox扩展包括main.js文件中的脚本

我正在为firefox编写扩展,并且在main.js(后台)文件中遇到包含脚本的问题…

在我的情况下,我想包括例如jquery.js和config.js但我无法看到如何正确地做到这一点。

在我的chrome扩展中,我只是在清单文件上执行此操作,但我希望在Firefox中具有相同function。

谢谢你的帮助,jdmry

要导入文件,请使用Components.utils.import 。

您将需要一个用于导入文件的URL。 通常,这是资源://或chrome:// URL。

Mozilla提供的库的一些示例:

Components.utils.import("resource://gre/modules/FileUtils.jsm"); //File Utilities Components.utils.import("resource://gre/modules/NetUtil.jsm"); //Network utilities Components.utils.import("resource://gre/modules/Services.jsm"); //Services 

从您自己的扩展程序加载的一些示例:

 Components.utils.import("chrome://myExtensionModule/content/common.jsm"); //Common Components.utils.import("chrome://myExtensionModule/content/classes.jsm"); //Classes 

要从您自己的扩展程序加载,您需要将文件放在已映射到chrome.manifest中的chrome://或resource:// URL的文件夹中。 例如,使用以下行:

 content myExtensionModule modules/ 

这不需要与您通常为内容映射的文件夹分开,但通常将JavaScript模块保存在单独的文件夹中,仅用于组织。 你不需要让他们使用.jsm扩展,再次只是一个约定。 使用.js就可以了,如果您有其他基于.js扩展名的自动配置工具(例如编辑器),则可能需要。

有关MDN的文档中可以找到更多信息:

  • JavaScript代码模块
  • 使用JavaScript代码模块
  • 附加SDK教程:创建可重用模块

请注意,在Firefox代码中,通常会有较短变量的映射来访问一些常用的Firefox属性。 具体而言,经常使用以下内容:

 const Cc = Components.classes; const Ci = Components.interfaces; const Cu = Components.utils; 

通常这些以更简化的方式定义。 它们在上面明确说明,以使映射更清晰。