中文字幕日韩一区二区_国产一区二区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的不足之處,轉載需保留來源!

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

主站蜘蛛池模板: 免费观看色 | 亚洲激精日韩激精欧美精品 | 久久精品国产亚洲一区二区三区 | 久草在线 | 99re在线视频 | 久久久久网站 | 免费看啪啪网站 | 国产精久久久久久久妇剪断 | 中文字幕福利视频 | 国产精品看片 | 欧美在线天堂 | 亚州一区二区三区 | 在线视频 欧美日韩 | 97操操 | 久久久精品一区 | 午夜精品久久 | 国产精品 亚洲一区 | 三级黄色片在线 | 一级aaaa毛片 | 日韩电影免费在线观看中文字幕 | 午夜三区| 免费成人高清在线视频 | 国产精品久久久久久久久久久久冷 | 久久r精品 | 欧美亚洲日本 | 91嫩草精品 | 九九综合九九 | 欧美日韩福利视频 | 俺去俺来也www色官网cms | 欧美激情 一区 | 在线观看视频一区二区三区 | 91麻豆精品国产91久久久久久久久 | 国产成人在线一区 | 精品美女 | 国产精品视频久久久 | 久久爱综合 | 久久综合狠狠综合久久综合88 | 日韩在线精品强乱中文字幕 | 国产真实乱全部视频 | 精品国产乱码久久久久久蜜退臀 | 免费精品久久久久久中文字幕 |