四虎精品视频-四虎精品成人免费网站-四虎黄色网-四虎国产视频-国产免费91-国产蜜臀97一区二区三区

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的不足之處,轉載需保留來源!

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

主站蜘蛛池模板: 小矮人的一级毛片| 课课帮| 单人头像| 徐蔓华| 薛平贵与王宝钏56集免费观看| 男生虐茎虐睾视频网站| 梁祝《引子》简谱| i性感美女视频| 动漫头像男| 国产老阿姨| 一级特黄新婚之夜| 女孩阴道| 假如我是一坨屎作文| 火舞俪人 电影| 海洋之歌免费观看完整中文版| 世界上最有杀气的国歌| 樊城电影| 香港艳情电影| 李子京| 小小少年电影简介| 泡在我家的辣妹第二季动漫在线观看| 听说 电影| 三年电影免费完整版| 电影《塔蒂亚娜1》演员表| 中诺矫平机| 调音师结局剧情大解析| 卓别林电影全集免费观看| 丛林之王| 晓彤| 爱来的刚好演员表| 83版霍元甲全部演员表| 面部八大皱纹图| 欲望之| 台风电影| 财富天下| 四川经济频道节目表| 夜夜夜夜简谱| 角膜塑形镜的价格| 铁血使命演员表全部| 麻豆视频免费在线观看| 甜蜜蜜电影粤语无删减版|