av激情亚洲男人的天堂国语,日韩欧美精品一中文字幕,无码av一区二区三区无码,国产又色又爽又刺激的a片,国产又色又爽又刺激的a片

詳解Javascript框架中的全局變量

對于Javascript框架,大家還是比較理解的。對于Javascript框架中的全局變量,大家還是要仔細的思考,這樣才能在開發(fā)過程中達到事半功倍的效果。

縱觀各大類庫的實現(xiàn),一開始基本都是定義一個全局變量,然后對它進行擴展。如Prototype.js的Prototype,mootools的Native,Base2的Base,Ext的Ext,JQuery的JQuery,YUI的YUI,dojo的dojo,MochiKit的MochiKit等等。從全局變量的污染程度來看,分為兩大類,Prototype,mootools與Base2歸一類。Prototype的哲學(xué)是對JS原生對象進行擴展。早些年,Ptototype差點成為事實的標(biāo)準(zhǔn),因此基本沒有考慮到與其他庫的共存問題?;赑rototype,也發(fā)展出諸如script.aculo.us,rico,Plotr,ProtoChart,Scripty2等非常優(yōu)秀的類庫以及一大堆收費插件,非JQuery那一大堆垃圾插件所能比擬的。不過,有點淵源的插件幾乎與Prototype有關(guān),如著名的lightbox。mootools是Prototype的升級版,更加OO,全面復(fù)制其API。Base則是想修復(fù)IE的Bug,讓IE擁有標(biāo)準(zhǔn)瀏覽器的API,因此也把所有原生對象污染一遍。

剩下幾個大類庫就奉行非侵入的原則,盡量減少全局變量。如Ext還有更多小型類庫,它會選擇一個自定義對象(其實也是window的一個自定義屬性),然后對它的屬性進行擴展。基本思路是

 
 
  1. Ext = {};   
  2. Ext.Element= function(){}   
  3. Ext.DomQuery = function(){}   
  4. Ext.DomHelper = function(){} 

jQuery也是一個window自定義屬性,而且從一開始就污染了兩個(JQurey與$),因此一旦其他類庫占用了$,它就退回用JQuery。它與Ext最大的不同的是。它是一個函數(shù)對象(Function),而不是一個純對象(Object)。它的所有擴展都是基于它的JQuery.fn即JQuery.prototype。其他可能暴露出來的變量都收到閉包與函數(shù)中。

dojo上來就來就構(gòu)建它無擬倫比的包機制。整個命名空間都是由eval生成,然后再慢慢往dojo上添加屬性,情況同Ext。不過,它的設(shè)計是我見過的類庫中最復(fù)雜的,涉及的領(lǐng)域也非常廣泛,搞到代碼量達到驚人的9千行(兼注釋)。

MochiKit不知是不是從dojo中派生出來,沒怎么研究。但它的組織形式與Ext與dojo很相似。

YUI與JQuery很相似,是一個函數(shù)對象,只不過它后面就沒有像JQuery那么瘋狂,什么都往原型中加。無疑,YUI與JQuery的理念是非常新穎的,函數(shù)比對象更能玩出花樣,起碼做鏈?zhǔn)讲僮饕草p松性。但JQuery一開始就瞄準(zhǔn)頁面的那個DOM元素,而YUI,dojo,Ptototype,mootools等具有強大繼承機制的,更樂意創(chuàng)建一個類,這就是JQuery在UI怎么也比不上它的前輩的原因。另外,YUI的作者們在CSS,HTML也造詣極深,因此其UI設(shè)計是非常值得學(xué)習(xí)的。


分享題目:詳解Javascript框架中的全局變量
轉(zhuǎn)載注明:http://uogjgqi.cn/article/dhesoei.html
掃二維碼與項目經(jīng)理溝通

我們在微信上24小時期待你的聲音

解答本文疑問/技術(shù)咨詢/運營咨詢/技術(shù)建議/互聯(lián)網(wǎng)交流