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