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