亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 編程 > JavaScript > 正文

jQuery中extend函數的實現原理詳解

2019-11-20 13:14:45
字體:
來源:轉載
供稿:網友

extend()是jQuery中一個重要的函數,作用是實現對對象的擴展, 它經常用于jQuery插件的開發,jQuery內部也使用它來擴展屬性方法,如上篇文章中講到的noConflict方法,就是用extend方法來擴展的。

在jQuery的API手冊中,我們看到,extend實際上是掛載在jQuery和jQuery.fn上的兩個不同方法,盡管在jQuery內部jQuery.extend()和jQuery.fn.extend()是用相同的代碼實現的,但是它們的功能卻不太一樣。來看一下官方API對extend的解釋:

復制代碼 代碼如下:

jQuery.extend(): Merge the contents of two or more objects together into the first object.(把兩個或者更多的對象合并到第一個當中)
jQuery.fn.extend():Merge the contents of an object onto the jQuery prototype to provide new jQuery instance methods.(把對象掛載到jQuery的prototype屬性,來擴展一個新的jQuery實例方法)

我們知道,jQuery有靜態方法和實例方法之分, 那么jQuery.extend()和jQuery.fn.extend()的第一個區別就是一個用來擴展靜態方法,一個用來擴展實例方法。用法如下:

jQuery.extend({ sayhello:function(){ console.log("Hello,This is jQuery Library"); }})$.sayhello(); //Hello, This is jQuery LibraryjQuery.fn.extend({ check: function() { return this.each(function() { this.checked = true; }); }, uncheck: function() { return this.each(function() { this.checked = false; }); }})$( "input[type='checkbox']" ).check(); //所有的checkbox都會被選擇

注意兩種調用插件的方式,一種是直接用$調用,另外一種是用$()調用,另外jQuery.extend()接收多個對象作為參數,如果只有一個參數,則把這個對象的屬性方法附加到jQuery上,如果含有多個參數,則把后面的對象的屬性和方法附加到第一個對象上。jQuery extend的實現源碼:

jQuery.extend = jQuery.fn.extend = function() { var options, name, src, copy, copyIsArray, clone, target = arguments[0] || {}, i = 1, length = arguments.length, deep = false; // Handle a deep copy situation if ( typeof target === "boolean" ) { deep = target; target = arguments[1] || {}; // skip the boolean and the target i = 2; } // Handle case when target is a string or something (possible in deep copy) if ( typeof target !== "object" && !jQuery.isFunction(target) ) { target = {}; } // extend jQuery itself if only one argument is passed if ( length === i ) { target = this; --i; } for ( ; i < length; i++ ) { // Only deal with non-null/undefined values if ( (options = arguments[ i ]) != null ) { // Extend the base object for ( name in options ) { src = target[ name ]; copy = options[ name ]; // Prevent never-ending loop if ( target === copy ) {  continue; } // Recurse if we're merging plain objects or arrays if ( deep && copy && ( jQuery.isPlainObject(copy) || (copyIsArray = jQuery.isArray(copy)) ) ) {  if ( copyIsArray ) {  copyIsArray = false;  clone = src && jQuery.isArray(src) ? src : [];  } else {  clone = src && jQuery.isPlainObject(src) ? src : {};  }  // Never move original objects, clone them  target[ name ] = jQuery.extend( deep, clone, copy ); // Don't bring in undefined values } else if ( copy !== undefined ) {  target[ name ] = copy; } } } } // Return the modified object return target;};

很大一堆代碼,乍看起來難以理解,其實代碼的大部分都是用來實現jQuery.extend()中有多個參數時的對象合并,深度拷貝問題,如果去掉這些功能,讓extend只有擴展靜態和實例方法的功能,那么代碼如下:

jQuery.extend = jQuery.fn.extend = function(obj){ //obj是傳遞過來擴展到this上的對象 var target=this; for (var name in obj){ //name為對象屬性 //copy為屬性值 copy=obj[name]; //防止循環調用 if(target === copy) continue; //防止附加未定義值 if(typeof copy === 'undefined') continue; //賦值 target[name]=copy; } return target;}

下面再來對extend方法進行注釋解釋:

jQuery.extend = jQuery.fn.extend = function() { // 定義默認參數和變量 // 對象分為擴展對象和被擴展的對象  //options 代表擴展的對象中的方法 //name 代表擴展對象的方法名 //i 為擴展對象參數起始值 //deep 默認為淺復制 var options, name, src, copy, copyIsArray, clone, target = arguments[0] || {}, i = 1, length = arguments.length, deep = false; //當第一個參數為布爾類型是,次參數定義是否為深拷貝 //對接下來的參數進行處理 if ( typeof target === "boolean" ) { deep = target; target = arguments[1] || {}; // 當定義是否深拷貝時,參數往后移動一位 i = 2; } // 如果要擴展的不是對象或者函數,則定義要擴展的對象為空 if ( typeof target !== "object" && !jQuery.isFunction(target) ) { target = {}; } // 當只含有一個參數時,被擴展的對象是jQuery或jQuery.fn if ( length === i ) { target = this; --i; } //對從i開始的多個參數進行遍歷 for ( ; i < length; i++ ) { // 只處理有定義的值 if ( (options = arguments[ i ]) != null ) { // 展開擴展對象 for ( name in options ) { src = target[ name ]; copy = options[ name ]; // 防止循環引用 if ( target === copy ) {  continue; } // 遞歸處理深拷貝 if ( deep && copy &&; ( jQuery.isPlainObject(copy) || (copyIsArray = jQuery.isArray(copy)) ) ) {  if ( copyIsArray ) {  copyIsArray = false;  clone = src && jQuery.isArray(src) ? src : [];  } else {  clone = src && jQuery.isPlainObject(src) ? src : {};  }  target[ name ] = jQuery.extend( deep, clone, copy ); // 不處理未定義值 } else if ( copy !== undefined ) {  //給target增加屬性或方法  target[ name ] = copy; } } } } //返回 return target;};

弄懂了jQuery擴展的原理,相信以后再也不用為編寫jQuery插件而煩惱了。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
国产精品成人免费电影| 成人久久一区二区| 在线观看日韩欧美| 亚洲日本欧美日韩高观看| 97碰在线观看| 国产精品久久激情| 亚洲成人av中文字幕| 久久久久久国产精品三级玉女聊斋| 成人午夜激情网| 欧美性理论片在线观看片免费| 亚洲精品美女在线观看| 中文字幕在线日韩| 亚洲男女自偷自拍图片另类| 成人观看高清在线观看免费| 国产精品99免视看9| 欧美成人午夜激情在线| 国产精品一区二区3区| 国产精品精品久久久| 国产精品丝袜一区二区三区| 91精品国产乱码久久久久久蜜臀| 国产欧美一区二区白浆黑人| 亚洲理论在线a中文字幕| 永久555www成人免费| 97视频免费在线看| 欧美激情欧美激情在线五月| 日韩高清电影免费观看完整版| 欧美激情在线观看| www国产精品com| 97视频免费在线看| 亚洲男人av电影| 日本韩国欧美精品大片卡二| 亚洲欧美制服综合另类| 久久99久久久久久久噜噜| 粗暴蹂躏中文一区二区三区| 久久久国产精品x99av| 亚洲成人动漫在线播放| 日韩中文av在线| 欧美大片免费观看在线观看网站推荐| 亚洲国产日韩欧美在线图片| 日韩在线观看你懂的| 最近2019年好看中文字幕视频| 中文字幕综合在线| 午夜欧美大片免费观看| 日韩美女视频免费在线观看| 中文字幕不卡在线视频极品| 中文字幕在线看视频国产欧美在线看完整| 亲爱的老师9免费观看全集电视剧| 亚洲欧美日韩国产精品| 色哟哟网站入口亚洲精品| 久久精品国产亚洲一区二区| 97国产精品免费视频| 在线观看不卡av| 久久av中文字幕| 国产中文欧美精品| 亚洲精品日韩在线| 91高潮精品免费porn| 91手机视频在线观看| 日韩欧美国产黄色| 亚洲999一在线观看www| 国产精品91视频| 成人性生交大片免费观看嘿嘿视频| 中文精品99久久国产香蕉| 久久欧美在线电影| 亚洲精品一区在线观看香蕉| 国产91在线播放九色快色| 51色欧美片视频在线观看| 久久久精品电影| 国产婷婷色综合av蜜臀av| 97热在线精品视频在线观看| 91国产精品电影| 亚洲精品永久免费| 日韩美女免费观看| 中文字幕久热精品视频在线| 日韩有码视频在线| 亚洲日本成人女熟在线观看| 久久精品在线播放| 亚洲亚裔videos黑人hd| 日韩一区二区精品视频| 欧美性xxxx极品hd欧美风情| 国产精品一区二区三区毛片淫片| 久久中文字幕在线视频| 最近2019年中文视频免费在线观看| 最近免费中文字幕视频2019| 午夜美女久久久久爽久久| 日韩中文字幕网| 久久久久久国产三级电影| 欧美高清理论片| 国产va免费精品高清在线| 欧美精品久久久久a| 国产精品丝袜一区二区三区| 亚洲第一天堂av| 欧美国产一区二区三区| 91系列在线播放| 国产精品999999| 国产精品网站大全| 久久精品免费播放| 欧美成年人视频网站欧美| 国产一区二区三区免费视频| 欧美午夜激情小视频| 欧美午夜激情视频| 欧美日韩一区二区三区在线免费观看| 欧美综合在线观看| 日韩美女视频免费看| 亚洲精品久久久一区二区三区| 欧美乱大交xxxxx| 97在线视频一区| 亚洲国产成人在线视频| 亚洲国产精品嫩草影院久久| 中文字幕精品影院| 日韩理论片久久| 中文字幕亚洲综合久久筱田步美| 在线播放国产精品| 久久99国产精品久久久久久久久| 在线视频欧美日韩精品| 国产美女直播视频一区| 欧美精品videossex性护士| 日本国产高清不卡| 亚洲人成欧美中文字幕| 欧美激情网友自拍| 北条麻妃在线一区二区| 日韩a**站在线观看| 欧美在线视频一二三| 欧美影院久久久| 欧美精品亚州精品| 疯狂做受xxxx高潮欧美日本| 亚洲精品电影久久久| 亚洲free性xxxx护士hd| 久久国产加勒比精品无码| 日韩欧美在线播放| 色99之美女主播在线视频| 亚洲欧美综合图区| 亚洲a在线观看| 久久免费视频观看| xvideos成人免费中文版| 精品视频偷偷看在线观看| 欧美亚洲国产另类| 97在线日本国产| 欧美激情精品久久久久久免费印度| 国产精品欧美在线| 亚洲欧美国产日韩中文字幕| 九九热精品视频| www.美女亚洲精品| 国产精品99久久99久久久二8| 亚洲欧美在线免费| 欧美黄色免费网站| 日韩亚洲欧美中文在线| 日韩欧美一区二区三区久久| 热re99久久精品国产66热| 国产欧美精品xxxx另类| 亚洲人成亚洲人成在线观看| 午夜精品久久久久久久99黑人| 亚洲国产精品99久久| 国产精品夫妻激情| 欧美极品美女电影一区| 精品呦交小u女在线| 日本a级片电影一区二区| 91po在线观看91精品国产性色| 中文字幕日韩在线观看| 精品美女永久免费视频| 日韩av成人在线| 亚洲国产精品久久久久秋霞蜜臀| 久久香蕉国产线看观看网| 日韩视频在线一区| 国产精品视频区1|