中文字幕日韩一区二区_国产一区二区av_国产毛片av_久久久久国产一区_色婷婷电影_国产一区二区精品

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都有比較好的支持。

it知識庫jQuery的不足之處,轉載需保留來源!

鄭重聲明:本文版權歸原作者所有,轉載文章僅為傳播更多信息之目的,如作者信息標記有誤,請第一時間聯系我們修改或刪除,多謝。

主站蜘蛛池模板: 一区二区高清 | 国产亚洲精品久久久久动 | 久久久久久999| 精品一区二区久久久久久久网站 | 欧美高清视频一区 | 精品国产一区二区三区久久久久久 | 伊人99| 国产精品九九 | 久久精品国产亚洲夜色av网站 | 成人在线看片 | 欧美中文字幕在线观看 | 日韩精品在线观看免费 | 久久国产高清 | 久久久噜噜噜久久中文字幕色伊伊 | 嫩草懂你的影院入口 | 久久久久久国产精品久久 | 一区二区精品在线 | 亚洲精品在线播放 | 久久99精品久久久久久国产越南 | 欧美午夜视频 | 欧美理论片在线 | 日韩视频在线观看中文字幕 | 天堂视频免费 | 日韩精品一区二区三区四区视频 | 999久久精品 | 成人自拍av | 福利视频亚洲 | 成年人在线观看 | 亚洲人成人一区二区在线观看 | 亚洲国产小视频 | 成人亚洲网站 | av三级在线观看 | 精品日韩一区二区三区av动图 | 国产精品高清一区二区 | 国产精品视频网站 | 91精品久久久久久久久久小网站 | 亚洲综合五月天婷婷 | 色婷婷综合网站 | 天天爽夜夜骑 | 国产在线一区二区三区 | 亚洲欧美中文日韩在线v日本 |