Jquery之美中不足小結(jié)
不過(guò),它也有一些不盡人意的地方。
1。關(guān)于代碼坨之一。
一直覺(jué)得jquery是個(gè)個(gè)人英雄主義的產(chǎn)物,有耐心看完他代碼的,絕對(duì)少于百分之一。
sizzle獨(dú)立出來(lái)后,ms有些改觀。
可一坨一坨并且相互牽連的風(fēng)格,還是在sizzle與jquery到處都是。
有時(shí)想:John如果不寫(xiě)代碼了,誰(shuí)會(huì)愿意來(lái)接手這些坨坨。
2。關(guān)于代碼坨之二。
不知有沒(méi)有組件開(kāi)發(fā)者想過(guò)“依賴jquery開(kāi)發(fā)出一個(gè)能不依賴jquery而獨(dú)立運(yùn)行的組件”?
這是奇怪的需求嗎?----好像不是。
有這樣的需求嗎?----很多同學(xué)會(huì)說(shuō):“jquery已經(jīng)樹(shù)大根深好乘涼可依賴,為什么還要獨(dú)立運(yùn)行。”
也是,組件開(kāi)發(fā)者的水平一般都還不錯(cuò),他們會(huì)想辦法解決這些問(wèn)題的。如果有這樣的需要,他們會(huì)去找到對(duì)應(yīng)的方法庫(kù)的。
不過(guò),這也說(shuō)明了,jquery不能滿足這些人的需求。
因?yàn)閖query就是個(gè)代碼坨。想拆成靜態(tài)方法庫(kù),那幾乎是不可能的。
3。關(guān)于“專注于dom”之一。
不知道該說(shuō)好,還是該說(shuō)不好。
覺(jué)得jquery的團(tuán)隊(duì),絕對(duì)有能力做一個(gè)全面的框架,而不只是停在“專注于dom”這一點(diǎn)上。
使用jquery與jquery組件,我們可能還得自己去找個(gè)種子文件,來(lái)作異步加載等。
因?yàn)檫@些的種子需求,其實(shí)是跟dom沒(méi)啥緊密關(guān)系的,所以jquery可以完全不顧-----倒是很會(huì)偷懶啊。
另,關(guān)于種子文件,YUI3把use當(dāng)核心點(diǎn)是個(gè)不錯(cuò)的創(chuàng)意,可惜發(fā)揮得有點(diǎn)太過(guò)。到Y(jié)UI3后,我想只用他的selector來(lái)作個(gè)性能比對(duì),竟然要加載一推文件才能做到。
4。關(guān)于“專注于dom”之二。
“jquery專注于dom”,
那字符串的trim,需要在jquery里嗎?----貌似沒(méi)必要吧。不過(guò)jquery順手提供了。類似的還有parseJSON、globalEval等。
那字符串模板功能(tmpl)呢?----模板明顯是應(yīng)該基于字符串的,因?yàn)樽址0宄S脕?lái)組織html字符,所以,jquery會(huì)把它牽強(qiáng)的放進(jìn)來(lái)。并且是基于dom的。----我實(shí)在想說(shuō):真的很牽強(qiáng)。
我們?cè)陧?xiàng)目中,可能還會(huì)用到很多跟字符串有關(guān)的功能(trim|subByte|encode4Hhtml等)、跟object有關(guān)的功能(get|dump|mix等)、跟數(shù)組有關(guān)的功能(forEach|map),等等。
這些問(wèn)題,jquery都沒(méi)有幫我們解決的意思,那我們是不是都得再另請(qǐng)高明或自已解決?
5。關(guān)于sizzle。
A:有時(shí)候覺(jué)得sizzle是個(gè)半成品,一些本來(lái)可以順手提供的功能,卻沒(méi)提供出來(lái)。
例如:
selector2filter(selector) //把一個(gè)selector轉(zhuǎn)化成一個(gè)過(guò)濾函數(shù)。
filter(els,selector,refEl) //以ref為參考元素,按selector條件過(guò)濾els。例如,在delegate時(shí)會(huì)用到。由于sizzle沒(méi)提供,導(dǎo)致$('#id').delegate('>li','click',handle)中的'>li'的參考元素不是#id對(duì)應(yīng)的對(duì)象
B:sizzle如果想解決以下這兩個(gè)問(wèn)題,可能得傷筋動(dòng)骨了。
<h1 id="head1">主題</h1>
<ul><li>明細(xì)1.1</li><li>明細(xì)1.2</li></ul>
<ul><li>明細(xì)2.1</li><li>明細(xì)2.2</li></ul>
<script>
alert($('#head1~ul>li').length);//應(yīng)該是4而不是0。因?yàn)閟izzle在取候選集時(shí)偷懶了,沒(méi)有認(rèn)真的處理候選集問(wèn)題
</script>
<ul>
<li>
<div>
<div>
<span>需要的</span>
</div>
</div>
</li>
<li>
<h1>
<div>
<span>不需要的</span>
</div>
</h1>
</li>
</ul>
<script>
alert($('li>div span').length); //應(yīng)該是1,而不是0。因?yàn)閟izzle在過(guò)濾時(shí)偷了懶,把回溯的情況給忽略了。
</script>
C:一點(diǎn)小想法,Sizzle的代碼有點(diǎn)多。YUI后有13K之多,去掉他額外加的幾個(gè)簡(jiǎn)寫(xiě),也還有11K多。
6。。。。
說(shuō)累了,以后再說(shuō)。
相關(guān)文章
分享20款美化網(wǎng)站的 jQuery Lightbox 燈箱插件
這篇文章主要介紹了分享20款美化網(wǎng)站的 jQuery Lightbox 燈箱插件,需要的朋友可以參考下2014-10-10jQuery實(shí)現(xiàn)遍歷復(fù)選框的方法示例
這篇文章主要介紹了jQuery實(shí)現(xiàn)遍歷復(fù)選框的方法,結(jié)合實(shí)例形式分析了jQuery針對(duì)表單復(fù)選框元素的遍歷與字符串操作相關(guān)技巧,需要的朋友可以參考下2017-03-03自定義jQuery插件方式實(shí)現(xiàn)強(qiáng)制對(duì)象重繪的方法
這篇文章主要介紹了自定義jQuery插件方式實(shí)現(xiàn)強(qiáng)制對(duì)象重繪的方法,實(shí)例分析了jQuery插件及對(duì)象重繪的技巧,具有一定參考借鑒價(jià)值,需要的朋友可以參考下2015-03-03jquery簡(jiǎn)單實(shí)現(xiàn)外部鏈接用新窗口打開(kāi)的方法
這篇文章主要介紹了jquery簡(jiǎn)單實(shí)現(xiàn)外部鏈接用新窗口打開(kāi)的方法,涉及jQuery正則匹配http://開(kāi)頭外部鏈接網(wǎng)址的相關(guān)技巧,需要的朋友可以參考下2015-05-05jquery Ajax實(shí)現(xiàn)Select動(dòng)態(tài)添加數(shù)據(jù)
這篇文章主要為大家詳細(xì)介紹了jquery Ajax實(shí)現(xiàn)Select動(dòng)態(tài)添加數(shù)據(jù)的相關(guān)資料,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2017-06-06jQuery Easyui使用(一)之可折疊面板的布局手風(fēng)琴菜單
這篇文章主要介紹了jQuery Easyui使用(一)之可折疊面板的布局手風(fēng)琴菜單的相關(guān)資料,非常不錯(cuò),具有參考借鑒價(jià)值,需要的朋友可以參考下2016-08-08從零開(kāi)始學(xué)習(xí)jQuery (十) jQueryUI常用功能實(shí)戰(zhàn)
本文是實(shí)戰(zhàn)篇. 使用jQueryUI完成制作網(wǎng)站的大部分常用功能.2011-02-02jQuery實(shí)現(xiàn)分頁(yè)功能(含ajax請(qǐng)求、后臺(tái)數(shù)據(jù)、附完整demo)
這篇文章主要給大家介紹了關(guān)于jQuery實(shí)現(xiàn)分頁(yè)功能的相關(guān)資料,主要包含ajax請(qǐng)求和后臺(tái)數(shù)據(jù),文末給出了完整的demo示例,對(duì)大家具有一定的參考價(jià)值,需要的朋友們下面來(lái)一起看看吧。2017-04-04