|
使用Jquery有一段時間了,對Jquery輕便、易學易用、方便的DOM操作以及這個框架的設(shè)計思想都由衷的贊嘆。但是Jquery在設(shè)計過程中也有一些不合理的地方(當然,有些東西見仁見智,可能你并不覺得這不合理),今天看到了一篇文章,覺得寫的挺有道理的,我做了一下整理。并不是說Jquery很差,讓大家不要用,而是通過這些內(nèi)容來更好的了解和使用jQuery。
1.each工具的回調(diào)函數(shù)參數(shù)的設(shè)計。
jQuery.each(obj,callback)
通用遍歷方法,可用于遍歷對象和數(shù)組。
不同于遍歷 jQuery 對象的 $().each() 方法,此方法可用于遍歷任何對象。回調(diào)函數(shù)擁有兩個參數(shù):第一個為對象的成員或數(shù)組的索引,第二個為對應變量或內(nèi)容。 如果需要退出 each 循環(huán)可使回調(diào)函數(shù)返回 false,其它返回值將被忽略。
很明顯,這個參數(shù)的設(shè)計不合理。應該將參數(shù)的順序?qū)φ{(diào)。原因很簡單,通常做遍歷的時候,我們只需要獲取當前對應的變量或內(nèi)容就可以了,大多數(shù)情況下是不需要索引的。如果索引參數(shù)在后面,在不使用的情況下就可以省略。也許你覺得我在雞蛋里面挑骨頭,你看看jQuery的另外一個工具的設(shè)計就清楚了:
jQuery.grep(array,callback,[invert])
這個工具是對對象和數(shù)組做遍歷用的,但是這個工具的callback函數(shù)的兩個參數(shù)中第一個為對應變量或內(nèi)容,第二個為對象的成員或數(shù)組的索引。正好與jQuery.each相反。
2.this指針的變換
在jQuery中this指針的變換是非常頻繁的,可能稍不留神,就會出錯。特別是在OO編程的時候。例如:
function Dog(){
this.name="旺財";
}
Dog.prototype.eat=function(){
$("div").click(function(){
alert(this.name+"在啃骨頭");
});
};
你會發(fā)現(xiàn)這段代碼并不會像你想象的那樣執(zhí)行,因為this指針已經(jīng)變換,指代的是當前的div對象,而不是Dog的實例。
3.jquery.inArray(value,array)工具的設(shè)計
就字面意思來說,這個函數(shù)應該返回true or false,事實上返回的是value在array第一次出現(xiàn)的位置。若不存在,返回-1。若你當作true或false來處理,就郁悶了,-1是true。
4.對OO的支持不夠
jquery的DOM操作的支持很好很強大,但在OO方面卻沒有做任何工作。而且,就jQuery的編碼風格也和OO有點格格不入。而其他框架如prototype,MooTools都有比較好的支持。
it知識庫:jQuery的不足之處,轉(zhuǎn)載需保留來源!
鄭重聲明:本文版權(quán)歸原作者所有,轉(zhuǎn)載文章僅為傳播更多信息之目的,如作者信息標記有誤,請第一時間聯(lián)系我們修改或刪除,多謝。