詳解Javascript框架中的全局變量
對于Javascript框架,大家還是比較理解的。對于Javascript框架中的全局變量,大家還是要仔細的思考,這樣才能在開發過程中達到事半功倍的效果。
縱觀各大類庫的實現,一開始基本都是定義一個全局變量,然后對它進行擴展。如Prototype.js的Prototype,mootools的Native,Base2的Base,Ext的Ext,JQuery的JQuery,YUI的YUI,dojo的dojo,MochiKit的MochiKit等等。從全局變量的污染程度來看,分為兩大類,Prototype,mootools與Base2歸一類。Prototype的哲學是對JS原生對象進行擴展。早些年,Ptototype差點成為事實的標準,因此基本沒有考慮到與其他庫的共存問題。基于Prototype,也發展出諸如script.aculo.us,rico,Plotr,ProtoChart,Scripty2等非常優秀的類庫以及一大堆收費插件,非JQuery那一大堆垃圾插件所能比擬的。不過,有點淵源的插件幾乎與Prototype有關,如著名的lightbox。mootools是Prototype的升級版,更加OO,全面復制其API。Base則是想修復IE的Bug,讓IE擁有標準瀏覽器的API,因此也把所有原生對象污染一遍。
剩下幾個大類庫就奉行非侵入的原則,盡量減少全局變量。如Ext還有更多小型類庫,它會選擇一個自定義對象(其實也是window的一個自定義屬性),然后對它的屬性進行擴展。基本思路是
- Ext = {};
- Ext.Element= function(){}
- Ext.DomQuery = function(){}
- Ext.DomHelper = function(){}
jQuery也是一個window自定義屬性,而且從一開始就污染了兩個(JQurey與$),因此一旦其他類庫占用了$,它就退回用JQuery。它與Ext最大的不同的是。它是一個函數對象(Function),而不是一個純對象(Object)。它的所有擴展都是基于它的JQuery.fn即JQuery.prototype。其他可能暴露出來的變量都收到閉包與函數中。
dojo上來就來就構建它無擬倫比的包機制。整個命名空間都是由eval生成,然后再慢慢往dojo上添加屬性,情況同Ext。不過,它的設計是我見過的類庫中最復雜的,涉及的領域也非常廣泛,搞到代碼量達到驚人的9千行(兼注釋)。
MochiKit不知是不是從dojo中派生出來,沒怎么研究。但它的組織形式與Ext與dojo很相似。
YUI與JQuery很相似,是一個函數對象,只不過它后面就沒有像JQuery那么瘋狂,什么都往原型中加。無疑,YUI與JQuery的理念是非常新穎的,函數比對象更能玩出花樣,起碼做鏈式操作也輕松性。但JQuery一開始就瞄準頁面的那個DOM元素,而YUI,dojo,Ptototype,mootools等具有強大繼承機制的,更樂意創建一個類,這就是JQuery在UI怎么也比不上它的前輩的原因。另外,YUI的作者們在CSS,HTML也造詣極深,因此其UI設計是非常值得學習的。
原文標題:javascript框架之全局變量
鏈接:http://www.cnblogs.com/rubylouvre/archive/2009/11/05/1596501.html