javascript框架有什么功能,這個(gè)不是框架作者隨意決定,這與人們經(jīng)常用JS做什么事直接相關(guān)。 javascript框架是從common.js這樣工具函數(shù)集演變過來,最重要的特征是實(shí)用。由于框架作者肯定是從一線開發(fā)人員過來的,這個(gè)他心里有數(shù),再結(jié)合主流框架的功能調(diào)查,就萬無一失了。
jQuery強(qiáng)在它專注于DOM操作的思路一開始就是對的,以后就是不斷在兼容性,性能上進(jìn)行改進(jìn)。
- ajax 數(shù)據(jù)交互(1.5來自社區(qū))
- attributes 屬性操作,共分className, 表單元素的value值,屬性與特征四大塊。
- callbacks 函數(shù)列隊(duì)
- core 種子模塊,命名空間,鏈?zhǔn)浇Y(jié)構(gòu),domReady,多庫共存。
- css 樣式操作,引入DE大神的兩個(gè)偉大的hacks,基本上解決精確獲取樣式的問題。
- data 數(shù)據(jù)存取。
- deferred 異步列隊(duì)(三合一版的函數(shù)列隊(duì))
- dimensions 元素尺寸的設(shè)置讀取(來自社區(qū))。
- effects 動畫引擎
- event 事件系統(tǒng)(基于DE大神的事件系統(tǒng)與社區(qū)的兩個(gè)插件)
- exports AMD系統(tǒng)(被RequireJS作者說服加幾行代碼支持其東東)
- manipulation 節(jié)點(diǎn)的操作
- offset 元素offsetTop(Left)的設(shè)置讀取(來自社區(qū))
- queue 列隊(duì)模塊(deferred與data的合體)。
- sizzle 從右到左進(jìn)行解析的選擇器引擎。
- support 特征偵測
- traversing 元素遍歷。
jQuery經(jīng)過多年的發(fā)展,擁有龐大的插件與完善的BUG提交渠道,因此可以通過社區(qū)的力量不斷完善自身。
早期的王者,它分為四大部分:
- 語言擴(kuò)展
- DOM擴(kuò)展
- AJAX部分
- 廢棄部分(新版本使用其他方法實(shí)現(xiàn)原有功能)
Prototype.js的語言擴(kuò)展覆蓋面非常廣,包括所有基本數(shù)據(jù)類型及從語言借鑒過來的“類”。 其中Enumerable 只是一個(gè)普通的方法包, ObjectRange,PeriodicalExecuter,Template 則用Class類工廠生產(chǎn)出來的。Class類工廠來自社區(qū)貢獻(xiàn),強(qiáng)大無比, 與mootools的類工廠不相伯仲。
DOM部分分成五塊。dom.js花了好大勁在IE下模擬Node, Element等對象, 并在Element原型上進(jìn)行擴(kuò)展。event.js就是跨瀏覽器的多投事件系統(tǒng)與domReady, 在早些年先進(jìn)到不得了,那個(gè)observe,fire,stopObserving的命名真是太好了。 form.js是專門處理表單。layout是專門處理樣式。selector.js是用于關(guān)聯(lián)選擇器引擎, 現(xiàn)在竟然用死對頭的Sizzle——shit, 真是落魄!
AJAX部分是重頭戲,早期框架最大的賣點(diǎn),里面N個(gè)對象都是用類工廠制造的,并存在多層的繼承關(guān)系。
比Prototype.js的入侵性更強(qiáng),但由于API設(shè)計(jì)得非常優(yōu)雅,官網(wǎng)上一大堆優(yōu)質(zhì)插件, 強(qiáng)大的團(tuán)隊(duì), 因此才沒有在原型擴(kuò)展的反對浪潮中沒落。
- Core 自1.3起,所有數(shù)據(jù)類型或原生對象都封裝成Type類型,Type方法可以說是其第一類工廠
- Type 對Number, Object(原Hash), String, Array, Function進(jìn)行擴(kuò)展, 事件對象的封裝
- Brower 檢測瀏覽器與OS的類型與版本, Flash版本, XMLHTTP對象的創(chuàng)建方法
- Class 第二類工廠
- Slick mootools的新一代選擇器引擎,支持CSS3高級偽類。
- Element 對元素的創(chuàng)建,克隆,插入,移除,樣式操作,事件綁定,事件代理進(jìn)行封裝
- Request 數(shù)據(jù)交互
- Fx 動畫引擎
- Utilities 對cookie, domReady, JSON, Flash(Swiff)提供便捷的工具方法
又一個(gè)在原型上進(jìn)行擴(kuò)展的框架,不過自創(chuàng)了許多東東。
- core 提供一個(gè)類工廠, Observer類, Option對象
- lang對array, function, json, math, number, object, regexp, string進(jìn)行擴(kuò)展與修復(fù)
- dom 提供各種dom 操作, 選擇器尋找, 事件綁定與代理, cookie, domReady
- fx 動畫引擎
- xhr 數(shù)據(jù)交互
- olds 對舊式IE的各種兼容
一個(gè)python風(fēng)格的框架,以前能進(jìn)世界前十名的。現(xiàn)在作者跑去當(dāng)CTO了。
- Base 提供命名空間, isXXX系列, 將操作符變成函數(shù),還有N多工具方法。
- Async 數(shù)據(jù)交互以及從python引進(jìn)Deferred(異步列隊(duì))。
- Color 顏色類型轉(zhuǎn)換。
- DOM 節(jié)點(diǎn)的增刪改查。
- Format 字符串與數(shù)字的格式化。
- DateTime 時(shí)間的格式化。
- DragAndDrop 拖放組件。
- Iter 一系列迭代器。
- Logger 調(diào)試用的日志。
- LoggingPane Logger帶UI的升級版。
- MochiKit 用document.write引進(jìn)框架的所有JS文件。
- Position 取得元素位置的相關(guān)方法。
- Selector 選擇器引擎。
- Signal 事件系統(tǒng)。
- Sortable 排序組件。
- Style 樣式操作。
- Test 單元測試。
- Visual 動畫引擎。
日本著名博客社區(qū)Hatena的javascript框架, 由日本頂尖高手amachang開發(fā),核心大致于2008年完工。 受Prototype.js影響, 但一點(diǎn)侵入性也沒有,是最早期以命名空間為導(dǎo)向的框架的典范。
- Ten對象,作為框架的基點(diǎn),所有模塊作為其屬性進(jìn)行擴(kuò)展。
- Ten.Class, 類工廠, 與Prototype.js1.6引入的類工廠很像,但比它早。
- Ten.Function, Ten.Array, 兩個(gè)方法包,提供一些工具方法。 除了這兩個(gè),Ten的其他模塊都是由類工廠制造出來。
- Ten.JSONP,估計(jì)世界上最早裝備JSONP的幾個(gè)javascript框架之一了。
- Ten.XHR,基于XMLHttpRequest的數(shù)據(jù)交互。
- Ten.Observer,提供訂閱發(fā)布機(jī)制, Prototype.js的泊來物。
- Ten.Event,Ten.EventDispatcher這兩個(gè)類分別對事件對象與多投事件進(jìn)行封裝。
- Ten.DOM DOM的增刪改查,里面有一個(gè)addObserver提供domReady功能。
- Ten.Element 用于創(chuàng)建元素。
- Ten.Cookie cookie的操作。
- Ten.Selector,Ten._Selector,Ten._SelectorNode與Ten.querySelector共同構(gòu)建其選擇器引擎。
- Ten.Color 顏色的轉(zhuǎn)換。
- Ten.Style 樣式的設(shè)置。
- Ten.Geometry 元素位置的偵測。
- Ten.Position 相當(dāng)于一個(gè)Point類。
- Ten.Logger 日志組件。
- Ten.Browser 瀏覽器嗅探。
- Ten.Deferred 由另一個(gè)日本頂尖高手cho45發(fā)明的異步列隊(duì), 日本人對此異步列隊(duì)的密集研究討論持續(xù)了三年多,可見這東西非常NB。
一個(gè)模塊化,以大模塊開發(fā)為目標(biāo),jQuery式的框架。里面涉及的HTML5新API數(shù)量,估計(jì)除了純凈的手機(jī)框架外,無人能敵。
- mass.js 種子模塊 提供類型識別 模塊加載 糅合機(jī)制 日志 高速化判定 domReady 簡單的事件綁定與移除 多庫共存 多版本共存。 別看這么多功能,其實(shí)本模塊體積是非常小的。
- lang.js 提供幾個(gè)isXXX方法,parseXXX方法,以及一個(gè)語言鏈對象。此對象能對字符串,數(shù)字,對象,類數(shù)組對象進(jìn)行優(yōu)雅的鏈?zhǔn)讲僮鳎?相當(dāng)于把Underscore.js這個(gè)庫整進(jìn)去,但兩者實(shí)現(xiàn)機(jī)理完全不一樣。
- lang_fix.js 補(bǔ)丁模塊, 提供ECMA262v5大部分新API的支持, 并修復(fù)IE一些BUG。
- support.js 特征嗅探
- class.js 類工廠
- query.js 第五代選擇器引擎Icarus, 兼容CSS3高級偽類與jQuery所有自定義偽類。
- node.js 提供一個(gè)節(jié)點(diǎn)鏈對象(與jQuery對象的API 95%兼容, 像wrap等不常用方法被剔除了)
- data.js 數(shù)據(jù)緩存
- css.js 相當(dāng)于jquery的css dimensions offset的三合一加強(qiáng)版,因?yàn)樗С諧SS3的transform2D。
- css_fx.js 補(bǔ)丁模塊, 將對舊式IE的兼并代碼獨(dú)立出去。
- target.js 對事件對象進(jìn)行封裝,并提供自定義事件機(jī)制。
- event.js 事件綁定與事件代理。
- flow.js 操作流,提供比異步列隊(duì)更強(qiáng)大的處理異步的機(jī)制。
- attr.js 屬性操作,同jQuery。
- ajax 數(shù)據(jù)交互。
- fx 動畫引擎。
經(jīng)過細(xì)節(jié)比較,我們很易得出以下結(jié)論
- 選擇器,domReady, ajax是現(xiàn)代框架的標(biāo)配。
- 動畫引擎,除非你的框架像Prototype.js那樣擁有像script.aculo.us這樣頂級的動畫框架做后盾,最好也加上。
- DOM操作是重中之重,節(jié)點(diǎn)的遍歷,樣式操作,屬性操作也屬于它的范疇,是否細(xì)分看你框架的規(guī)模。由于完全模塊化了, mass Framework基至可以將舊式IE的兼容代碼獨(dú)立出去。
- 現(xiàn)在主流的事件系統(tǒng)都支持事件代理了。
- 對基本數(shù)據(jù)類型的操作是必須的,像jQuery還是不得不提供trim, camelCase, each, map等方法。 像Prototype.js等侵入式框架則可以肆無忌憚地在原型上添加camelize等好用方法。
- 類型的判定必不可少,常見形式是isXXX系列。
- brower sniff已死, feature detect當(dāng)立。
- 異步列隊(duì)等處理回調(diào)的方案的流行
- 即使不專門提供一個(gè)類工廠,也應(yīng)該存在一個(gè)叫extend或mixin的方法對對象進(jìn)行擴(kuò)展。 jQuery雖然沒有類工廠,但在jQuery ui中也不得不整一個(gè),可見其重要性。
- 自從jQuery搞鼓出一個(gè)叫noConflict的方法,新興的小庫們都帶此方法,以求狹縫中生存。
- 許多框架是非常重視cookie的操作。
最后嘮叨一下,當(dāng)你成為高手時(shí),一定已經(jīng)在寫或?qū)戇^框架了。這就像一位劍豪,必然開創(chuàng)自己的流派。為什么前端的工資普遍不如后端呢,正是因?yàn)榍岸薐Ser的平均水平實(shí)在太低了,大多數(shù)人不是科班出身, 還懶得要命, 寫幾行代碼還上網(wǎng)找插件, 扣人家代碼, 具備寫框架功能的人實(shí)在太少了。PHP框架數(shù)量上千個(gè),天天在增加。java, C, C#的人不但玩框架,還玩編譯器,制造語言去了。而能玩ruby, python的人基本上衣食無憂, 閑得蛋疼,不說了。就前端,特別是中國前端的人的整體素質(zhì)最差, 既然你只會jQuery, 老板隨便拉幾個(gè)后端學(xué)上一兩天也會jQuery,要你何用?!本段話是針對“不要重復(fù)造輪子”的人說的。其實(shí)老外也沒有說過這句話,人家是說,“不要重復(fù)發(fā)明輪子”。為了不成為前端攻城師當(dāng)炮灰, 大家努力搞鼓個(gè)框架出來當(dāng)前端架構(gòu)師吧。