`
zhaohaolin
  • 浏览: 1017248 次
  • 性别: Icon_minigender_1
  • 来自: 杭州
社区版块
存档分类
最新评论

Firefox扩展开发: Hello World!【转】

阅读更多
今天尝试开发一个Firefox的扩展。虽然比较简单,网上也有很多教程,但是感觉一些教程写的比较麻烦,在初步的开发过程中并没有用到那些东西,于是自己把开发过程记录下来。我是根据Mozilla官方教程开发的,有兴趣的朋友可以自己去看看:https://developer.mozilla.org/en/Building_an_Extension

按照一般的教程,第一个程序都是使用最简单的Hello World,现在我们就制作一个Firefox的Hello World扩展。

开发Firefox插件并没有看上去的那样复杂,仅仅使用XML和JavaScript就可以完成。当然,这个意思是Firefox插 件开发使用的技术是XML和JavaScript,要做出一个完善的插件涉及到很多方面。但是对于我们的Hello World就不需要那么多东西啦!

1. 准备目录结构

首先在硬盘上建立一个目录,名为extension。这个名字是随意取的。然后在里面建立chrome文件夹,再在chrome里面建 立content文件夹。注意这两个文件夹的名字都是固定的,不能随意改动。然后在extension里面新建两个文本文件,并且取名为 chrome.manifest和install.rdf。这样,就建立起如下的目录结构:
extension
|--install.rdf
|--chrome.manifest
|--chrome
    |--content

2. 编写install.rdf

用文本编辑器打开install.rdf文件,输入以下内容:
<? xml version ="1.0" ?>

< RDF xmlns ="http://www.w3.org/1999/02/22-rdf-syntax-ns#"
         xmlns:em ="http://www.mozilla.org/2004/em-rdf#" >

    < Description about ="urn:mozilla:install-manifest" >
        <!-- 指出扩展的ID。该ID应该是一个Email格式的字符串,或者是一个GUID。注意,使用Email的作用是保证该ID的唯一性,并不要求这个Email地址是有效的。必填。 -->
        < em:id > sample@example.net</ em:id >
        <!-- 指出插件的版本号。必填。 -->
        < em:version > 1.0</ em:version >
        <!-- 在这里的值必须是2。该标签说明该应用的Firefox扩展,而不是其他XUL应用程序。Firefox插件的代码是2,如果是Firefox主题则会是4。必填。 -->
        < em:type > 2</ em:type >
        
        <!-- 安装扩展的目标应用程序以及最高版本和最低版本。必填。 -->
        < em:targetApplication >
            < Description >
                <!-- Firefox的ID,这个值不能改变。必填。 -->
                < em:id > {ec8030f7-c20a-464f-9b0e-13a3a9e97384}</ em:id >
  <!-- 指明能使用该扩展的Firefox最低版本。这里是指1.5。必填。 -->
                < em:minVersion > 1.5</ em:minVersion >
  <!-- 指明能使用该扩展的Firefox最高版本。这里是指3.0.x。结合minVersion,即是说本扩展只适用于1.5和3.0.x之间的版本。必填。 -->
                < em:maxVersion > 3.0.*</ em:maxVersion >
            </ Description >
        </ em:targetApplication >
        
        <!-- 扩展的元数据。 -->
        <!-- 扩展 名字。必填。 -->
        < em:name > sample</ em:name >
        <!-- 扩展 的描述。这里的描述将出现在Firefox的工具-附加组件的描述栏。选填。 -->
        < em:description > A test extension</ em:description >
        <!-- 扩展 作者。选填。 -->
        < em:creator > galaxy.org</ em:creator >
        <!-- 扩展 主页的URL。选填。 -->
        < em:homepageURL > http://www.example.com/</ em:homepageURL >
    </ Description >             
</ RDF >
 
install.rdf文件是供具有扩展管理功能的XUL应用程序使用的,XUL应用程序可以使用该文件识别正在安装的扩展的信息。install.rdf文件具有下面的格式:
 
<? xml version ="1.0" ?>

< RDF xmlns ="http://www.w3.org/1999/02/22-rdf-syntax-ns#"
         xmlns:em ="http://www.mozilla.org/2004/em-rdf#" >
    < Description about ="urn:mozilla:install-manifest" >
        <!-- properties -->
    </ Description >
</ RDF >
 
上面的install.rdf的注释很多,实际应用中就不需要那么多注释了。
 
3. 编写XUL文件
 
Firefox的界面使用XUL和JavaScript进行描述。XUL即XML User Interface Language,是Mozilla开发的一种使用XML进行用户界面描述的语言。XUL只用来定义用户界面,其组件的功能由JavaScript进行定义。
 
Firefox的整个界面都使用XUL进行定义。可以在%FIREFOX_INSTALL_DIR%/chrome/browser.jar里 面找到content/browser/browser.xul文件。(说明一下,jar文件可以用WinRAR或其他一些压缩工具解压缩,这是一个使用 zip算法压缩的压缩包)在这个XUL文件中有这么一段:
 
< statusbar id ="status-bar" >
<!-- ... <statusbarpanel>s ... -->
</ statusbar >
 
这里的这个<statusbar id="status-bar">称为“覆盖点(Overlay,我不知道官方的翻译是什么,自己把它翻译成了这个词,想想还算是准确,不过为了不 引起混淆,下面还是使用Overlay这个单词吧 :-) )”。所谓Overlay,就是在运行一个XUL文档的时候可以附加其他的XUL文件的方式。就是说,我们本来的XUL是a.xul,这里面有一个 Overlay定义为overlay-point,那么我们可以在另外一个b.xul中对这个Overlay进行追加,从而在执行a.xul的时候可以自 动的把b.xul的内容附加到overlay-point并运行出来。这么说有些抽象,来看我们的代码:
 
<? xml version ="1.0" ?>
< overlay id ="sample"     
                 xmlns ="http://www.mozilla.org/keymaster/gatekeeper/there.is.only.xul" >
< statusbar id ="status-bar" >
    < statusbarpanel id ="my-panel" label ="Hello, World"     />
</ statusbar >
</ overlay >
 
刚刚说了,<statusbar id="status-bar">就是一个Overlay,那么在我们的插件的XUL文档就是基于这个Overlay进行扩展。在这里,我们在 statusbar上面定义了一个statusbarpanel,它的id是my-panel,label是Hello, World。这段代码比较清晰,就是在原有的statusbar上追加一个statusbarpanel,这个statusbarpanel显示 Hello, World。
 
明白了这段代码之后,我们把这个文件定义成sample.xul,保存在chrome/content下面。可以看到这个文件夹结构和Firefox自有的那个结构是一致的。
 
在写完了XUL文件之后,我们要定义其chrome.manifest。XUL文档需要通过chrome://协议进行请求。chrome://类似http://协议,只不过是用来请求XUL文档的。在Firefox的地址栏中输入chrome://browser/content/browser.xul ,看看有什么反应,就会知道XUL文档的作用了。
 
这个URL包括四部分:
1) chrome:// - 即协议名,就像http://一样;
2) browser/ - 包名,即插件的包的ID;
3) content/ - 请求内容的类型;
4) browser.xul - 请求的文件名。
所以,chrome://foo/skin/bar.png 就是请求一个在foo包下面的skin里面的bar.png文件。
 
4. 编写chrome.manifest
 
在chrome.manifest中添加下面一句:
 
content         sample        chrome/content/
 
这里指明,请求类型时content,包名是sample,位置是相对于chrome.manifest文件的chrome/content/。注意,这里的最后面一个/是不能缺少的!
 
然后需要告诉Firefox我们的扩展Overlay,在chrome.manifest里面再添加一句:
 
overlay chrome://browser/content/browser.xul chrome://sample/content/sample.xul
 
这句是告诉Firefox,需要在chrome://browser/content/browser.xul加载的时候将chrome://sample/content/sample.xul扩展进来。
 
5. 测试
 
至此,我们已经完成了这个Hello World的扩展。下面我们测试一下。
 
使用压缩工具将extension文件夹压缩成zip文件,注意有些工具会将本文件夹加入压缩包,这里要求压缩包解开之后应该是 extension下面的两个文件和一个文件夹,而不是extension文件夹。然后将后缀名改为xpi。然后打开Firefox(我测试的版本是 3.0.10),将这个xpi拖到窗口中,Firefox将提示安装扩展,按照一般的过程安装之后,重启Firefox有时候在安装扩展时会有找不到安装 脚本的错误,就是因为在压缩时根下面没有install.rdf那一层导致的。
 
当我们在重启Firefox之后,右下角出现Hello, Word字样时,说明我们的扩展已经安装成功了!

本文出自 “豆子空间 ” 博客,请务必保留此出处http://devbean.blog.51cto.com/448512/160298

分享到:
评论

相关推荐

    Firefox扩展实例-HelloWorld

    在本实例"Firefox扩展-HelloWorld"中,我们将探讨如何创建一个基础的Firefox扩展,以此来理解其基本架构和开发过程。 首先,"helloworld.xpi"文件是Firefox扩展的打包格式,类似于其他软件的安装程序。XPI...

    火狐扩展插件HelloWorld项目

    "HelloWorld"项目就是一个典型的入门级教程,旨在帮助初学者了解如何开发自己的火狐扩展。 开发火狐扩展通常涉及以下几个关键知识点: 1. **XUL(XML User Interface Language)**:XUL是Mozilla使用的一种标记...

    firefox 最新开发文档

    这份文档涵盖了从基础的插件开发到高级的浏览器扩展技术,为想要参与Firefox生态建设的开发者提供了详尽的指南。 首先,让我们从"Firefox 插件"开始。Firefox插件是一种轻量级的软件组件,它们可以增强浏览器的功能...

    firefox附加组件开发者指南

    从下一章开始,我们将深入探讨如何使用这些技术来构建具体的扩展实例,包括一个简单的“Hello World”扩展和一个实用的会话管理扩展。通过实际操作,你将能够更好地理解和掌握Firefox扩展开发的全过程。

    hello-world:适用于 Firefox OS 的 hello world 应用程序

    "你好,世界!"是编程领域的一个传统,用于初次接触新语言或平台时的简单示例。...通过深入研究和扩展这个基础应用,开发者可以逐步掌握Firefox OS应用开发的精髓,并创建出更加丰富和功能强大的应用程序。

    w3cshool之JavaScript对象_String

    在Firefox和IE中,这个属性都是可用的。 - `prototype`:这个属性用于扩展对象的功能,可以添加新的方法或者属性。 2. **方法**: - `anchor()`:创建一个HTML锚点,如`&lt;a name="myanchor"&gt;Hello world!&lt;/a&gt;`。 ...

    Firefox 技巧:如何同时打开多个书签或网址

    Mozilla Firefox作为一款流行的网络浏览器,提供了许多扩展和技巧,以提高用户的多任务处理能力。本文将介绍几种在Firefox中同时打开多个书签或网址的技巧。 首先,需要了解的是Multi Links扩展。这是一个功能强大...

    Matchstick-Hello-World:MatchStick 的 Hello World 应用程序 (http

    【火柴棍-Hello-World】是针对MatchStick设备的一个入门级应用程序,它展示了如何在基于Firefox OS的流媒体棒上开发和运行基本应用。MatchStick是一款以Firefox操作系统为平台的流媒体设备,类似于Google的...

    jQuery学习笔记之Helloworld

    此外,jQuery对浏览器的广泛兼容性也是其亮点,它支持包括Internet Explorer 6.0+、Firefox 1.5+、Safari 2.0+、Opera 9.0+在内的多种浏览器,消除了开发者在跨浏览器兼容性上的烦恼。 jQuery的使用使得DOM操作变得...

    PHP程序设计教案.doc

    用户通过WEB浏览器(如IE、Firefox)发送HTTP请求到WEB服务器。\n2. WEB服务器接收到请求后,如果请求涉及到PHP文件,它会调用PHP预处理器来解释执行PHP代码。\n3. PHP预处理器将PHP代码转换成HTML文本,这个文本...

    xajax实例!!!

    4. **兼容性**:xajax 与大多数现代浏览器兼容,包括 Internet Explorer、Firefox、Chrome 和 Safari 等,这使得开发的 AJAX 应用程序具有广泛的用户覆盖范围。 5. **社区支持**:作为开源项目,xajax 有一个活跃的...

    js设置兼容trim函数

    尽管现代浏览器(如Chrome、Firefox、Safari等)普遍支持`trim()`方法,但较旧版本的Internet Explorer(如IE8及以下版本)并不支持该方法。这导致在这些浏览器中使用`trim()`时会出现错误或无法正常工作。 #### ...

    普元eos帮助文档

    此外,NUI前端框架支持主流的浏览器,如IE6+、Firefox、Chrome等,这为项目的广泛部署提供了坚实的基础。NUI的稳定性和扩展性都非常出色,并且能够支持平滑的版本升级,这使得它能够应对大多数的业务场景。 ### ...

    python爬虫 使用selenium 实现中英互译

    常见的WebDriver有ChromeDriver和GeckoDriver(用于Firefox)。根据README的指示,你可能需要下载对应的WebDriver并配置环境变量,以便Selenium能够找到它。 在编写Selenium脚本时,你会学习到如何定位网页元素,...

    PHP程序设计电子教案.doc

    PHP程序文件通常以`.php`为扩展名,如`helloworld.php`。一个简单的PHP程序示例是打印“Hello World!”以及当前日期和时间。 PHP脚本程序的工作流程包括以下几个关键步骤: 1. 用户使用WEB浏览器(如IE、Firefox)...

    Silverlight开发教程.pdf

    Silverlight运行在Windows和Mac OS X操作系统上的主流浏览器,支持IE、Firefox和Safari等浏览器。它主要由XAML(可扩展应用程序标记语言)来描述用户界面,并且可以使用C#、***、JavaScript等多种编程语言来编写业务...

    jquery\jQuery基础教程.pdf

    - **兼容性**:支持多种浏览器,包括IE6.0+、Firefox1.5+、Safari2.0+和Opera9.0+等。 - **可扩展性**:开发者可以轻松为其添加新的功能和插件,极大地扩展了jQuery的应用范围。 #### 二、jQuery的重要性及其适用...

    QtWebassembly 测试demo

    开发者可以使用Chrome开发者工具或Firefox开发者工具进行调试,这些工具提供了对WebAssembly模块的深入洞察。 **性能优化** 虽然QtWebAssembly提供了一种便捷的跨平台方式,但需要注意的是,WebAssembly在浏览器中...

    TinyMCE开发笔记

    tinymce.activeEditor.setContent('&lt;p&gt;Hello World!&lt;/p&gt;'); // 触发保存事件 tinymce.triggerSave(); ``` 六、TinyMCE自定义开发 对于高级用户,TinyMCE允许自定义主题、创建新插件,甚至修改源码。例如,如果你想...

Global site tag (gtag.js) - Google Analytics