中文字幕二区_国产精品免费在线观看_黄色网站观看_人人草人人澡_日本真实娇小xxxx

您的位置: 首頁 > 技術(shù)文檔 > 網(wǎng)頁制作 > Firefox擴(kuò)展的全局命名空間污染
快速寫出較好CSS的5種方法 回到列表 完美的CSS絕對底部
 Firefox擴(kuò)展的全局命名空間污染

作者:明達(dá) 時間: 2009-02-25 文檔類型:翻譯 來自:七月佑安

第 1 頁 Firefox擴(kuò)展的全局命名空間污染 [1]
第 2 頁 Firefox擴(kuò)展的全局命名空間污染 [2

下面這些代碼是browserOverlay.js文件的內(nèi)容,這個腳本文件會在一個界面文件(browserOverlay.xul)中被引用。

// 擴(kuò)展對應(yīng)的唯一全局變量
var myExtension = {};
(function() { // 注冊命名空間
  var namespaces = [];
  this.ns = function(fn) {
      var ns = {};
      namespaces.push(fn, ns);
      return ns;
  };

  // 初始化
  this.initialize = function() {
      for (var i = 0; i < namespaces.length; i += 2) {
          var fn = namespaces[i];
          var ns = namespaces[i + 1];
          fn.apply(ns);
      }
  };

  // 收尾的清理工作
  this.shutdown = function() {
      window.removeEventListener("load", myExtension.initialize, false);
      window.removeEventListener("unload", myExtension.shutdown, false);
  };

  // 注冊兩個事件處理程序,維護(hù)擴(kuò)展的生存期
  window.addEventListener("load", myExtension.initialize, false);
  window.addEventListener("unload", myExtension.shutdown, false);
}).apply(myExtension);

正如我前文所述,這里只有一個全局對象myExtension。

總結(jié)一下,這個對象要實(shí)現(xiàn)下面幾個方法:

  • ns - 注冊一個新的命名空間。
  • initialize - 初始化所有的命名空間。
  • shutdown - 收尾的清理工作。

當(dāng)然這段代碼也會確保initialize和shutdown方法會在正確的時間被調(diào)用,這也是兩個事件處理程序的作用。

browserOverlay.xul現(xiàn)在看起來可能會是下面這個樣子:

<?xml version="1.0"?>
<overlay xmlns="http://www.mozilla.org/keymaster/gatekeeper/
there.is.only.xul">
  <script src="chrome://namespace/content/browserOverlay.js" type="application/x-javascript"/>
  <script src="chrome://namespace/content/Module1.js" type="application/x-javascript"/>
  <script src="chrome://namespace/content/Module2.js" type="application/x-javascript"/>
</overlay>

在這里,Module1.js和Module2.js兩個文件是一模一樣的。

myExtension.ns(function() {
  // TODO: 腳本內(nèi)的全部代碼
});

在不同的模塊間共享數(shù)據(jù)

我們已經(jīng)把所有的腳本置于本地的作用域下,現(xiàn)在讓我們來回答上面提到的第二個問題,就是在不同的命名空間下如何共享函數(shù)和數(shù)據(jù)。基本的思路當(dāng)然是要利用我們唯一的全局對象啦,也就是myExtension。

首先,讓我們先來看看下面這段代碼(都在lib.js文件中)

myExtension.LIB = {
  // 共享函數(shù)接口
  getCurrentURI: function() {
      return window.location.href;
  },

  // 擴(kuò)展對象的快捷方式
  theApp: myExtension,

  // XPCOM組件的快捷方式
  Cc: Components.classes,
  Ci: Components.interfaces,

  // 等等。。。
};

你可以注意到,這段代碼在全局的myExtension對象下建立了一個新的LIB屬性,這個屬性定義了一個函數(shù)庫,是要在擴(kuò)展所有的模塊中共享的。你應(yīng)該在Java的包結(jié)構(gòu)中看到過相同的做法,所有的命名空間呈樹狀結(jié)構(gòu)分布在一個唯一的對象下面,YUI也是這樣子做的。

lib.js文件也在browserOverlay.xul中引入,緊隨browserOverlay.js的后面。

<?xml version="1.0"?>
<overlay xmlns="http://www.mozilla.org/keymaster/gatekeeper/
there.is.only.xul">
  <script src="chrome://myextension/content/browserOverlay.js" type="application/x-javascript"/>
  <script src="chrome://myextension/content/lib.js" type="application/x-javascript"/>
  <script src="chrome://myextension/content/Module1.js" type="application/x-javascript"/>
  <script src="chrome://myextension/content/Module2.js" type="application/x-javascript"/>
</overlay>

讓我們對模塊內(nèi)的腳本也做一些改進(jìn)。

myExtension.ns(function() {
  with(myExtension.LIB) {
      // TODO: 腳本內(nèi)的全部代碼
      var moduleVariable = "Accessible only from withing this module";
      dump("myExtension.Module initialization " + getCurrentURI() + "\n");
  }
});

通過利用with語句,我們可以方便的訪問所有的庫函數(shù),就像訪問全局變量一樣。

既然我們要訪問全局對象,還可以像下面這樣利用theApp這個快捷方式(尤其是命名空間名字太長的時候)

myExtension.ns(function() {
  with(myExtension.LIB) {
      // TODO: 腳本內(nèi)的全部代碼
      theApp.sharedValue = "A new shared property";
  }
});

下面這個圖是從UML的角度來縱觀整個架構(gòu)。

大家可以在 這里 下載本文提到的演示擴(kuò)展。

本文鏈接:http://m.95time.cn/tech/web/2009/6452.asp 

出處:七月佑安
責(zé)任編輯:bluehearts

上一頁 Firefox擴(kuò)展的全局命名空間污染 [1] 下一頁

◎進(jìn)入論壇網(wǎng)頁制作WEB標(biāo)準(zhǔn)化版塊參加討論,我還想發(fā)表評論

相關(guān)文章 更多相關(guān)鏈接
關(guān)于基于字體大小(em)的設(shè)計(jì)
Firefox中復(fù)制/粘貼進(jìn)階技巧
Opera不比Firefox差
JS擴(kuò)展Photoshop新功能
firefox擴(kuò)展插件制作方法
作者文章 更多作者文章
提升JavaScript運(yùn)行速度之函數(shù)篇
有趣的JavaScript數(shù)組
瀏覽器根據(jù)什么來判定腳本失控?
提升JavaScript運(yùn)行速度之循環(huán)篇
JavaScript中盡量用局部變量的原因
關(guān)鍵字搜索 常規(guī)搜索 推薦文檔
熱門搜索:CSS Fireworks 設(shè)計(jì)比賽 網(wǎng)頁制作 web標(biāo)準(zhǔn) 用戶體驗(yàn) UE photoshop Dreamweaver Studio8 Flash 手繪 CG
站點(diǎn)最新 站點(diǎn)最新列表
周大!熬•自然”設(shè)計(jì)大賽開啟
國際體驗(yàn)設(shè)計(jì)大會7月將在京舉行
中國國防科技信息中心標(biāo)志征集
云計(jì)算如何讓安全問題可控
云計(jì)算是多數(shù)企業(yè)唯一擁抱互聯(lián)網(wǎng)的機(jī)會
阿里行云
云手機(jī)年終巨獻(xiàn),送禮標(biāo)配299起
阿里巴巴CTO王堅(jiān)的"云和互聯(lián)網(wǎng)觀"
1499元買真八核 云OS雙蛋大促
首屆COCO桌面手機(jī)主題設(shè)計(jì)大賽
欄目最新 欄目最新列表
淺談JavaScript編程語言的編碼規(guī)范
如何在illustrator中繪制臺歷
Ps簡單繪制一個可愛的鉛筆圖標(biāo)
數(shù)據(jù)同步算法研究
用ps作簡單的作品展示頁面
CSS定位機(jī)制之一:普通流
25個最佳最閃亮的Eclipse開發(fā)項(xiàng)目
Illustrator中制作針線縫制文字效果
Photoshop制作印刷凹凸字體
VS2010中創(chuàng)建自定義SQL Rule
>> 分頁 首頁 前頁 后頁 尾頁 頁次:2/21個記錄/頁 轉(zhuǎn)到 頁 共2個記錄

藍(lán)色理想版權(quán)申明:除部分特別聲明不要轉(zhuǎn)載,或者授權(quán)我站獨(dú)家播發(fā)的文章外,大家可以自由轉(zhuǎn)載我站點(diǎn)的原創(chuàng)文章,但原作者和來自我站的鏈接必須保留(非我站原創(chuàng)的,按照原來自一節(jié),自行鏈接)。文章版權(quán)歸我站和作者共有。

轉(zhuǎn)載要求:轉(zhuǎn)載之圖片、文件,鏈接請不要盜鏈到本站,且不準(zhǔn)打上各自站點(diǎn)的水印,亦不能抹去我站點(diǎn)水印。

特別注意:本站所提供的攝影照片,插畫,設(shè)計(jì)作品,如需使用,請與原作者聯(lián)系,版權(quán)歸原作者所有,文章若有侵犯作者版權(quán),請與我們聯(lián)系,我們將立即刪除修改。

您的評論
用戶名:  口令:
說明:輸入正確的用戶名和密碼才能參與評論。如果您不是本站會員,你可以注冊 為本站會員。
注意:文章中的鏈接、內(nèi)容等需要修改的錯誤,請用報(bào)告錯誤,以利文檔及時修改。
不評分 1 2 3 4 5
注意:請不要在評論中含與內(nèi)容無關(guān)的廣告鏈接,違者封ID
請您注意:
·不良評論請用報(bào)告管理員,以利管理員及時刪除。
·尊重網(wǎng)上道德,遵守中華人民共和國的各項(xiàng)有關(guān)法律法規(guī)
·承擔(dān)一切因您的行為而直接或間接導(dǎo)致的民事或刑事法律責(zé)任
·本站評論管理人員有權(quán)保留或刪除其管轄評論中的任意內(nèi)容
·您在本站發(fā)表的作品,本站有權(quán)在網(wǎng)站內(nèi)轉(zhuǎn)載或引用
·參與本評論即表明您已經(jīng)閱讀并接受上述條款
推薦文檔 | 打印文檔 | 評論文檔 | 報(bào)告錯誤  
專業(yè)書推薦 更多內(nèi)容
網(wǎng)站可用性測試及優(yōu)化指南
《寫給大家看的色彩書1》
《跟我去香港》
眾妙之門—網(wǎng)站UI 設(shè)計(jì)之道
《Flex 4.0 RIA開發(fā)寶典》
《贏在設(shè)計(jì)》
犀利開發(fā)—jQuery內(nèi)核詳解與實(shí)踐
作品集 更多內(nèi)容

雜⑦雜⑧ Gold NORMANA V2