這篇文章主要介紹jQuery中extend()與工具方法、實例方法的示例分析,文中介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們一定要看完!
創(chuàng)新互聯(lián)-專業(yè)網(wǎng)站定制、快速模板網(wǎng)站建設(shè)、高性價比柞水網(wǎng)站開發(fā)、企業(yè)建站全套包干低至880元,成熟完善的模板庫,直接使用。一站式柞水網(wǎng)站制作公司更省心,省錢,快速模板網(wǎng)站建設(shè)找我們,業(yè)務(wù)覆蓋柞水地區(qū)。費用合理售后完善,10年實體公司更值得信賴。
具體如下:
使用jQuery的時候會發(fā)現(xiàn),jQuery中有的函數(shù)是這樣使用的:
$.get(); $.post(); $.getJSON();
有些函數(shù)是這樣使用的:
$('div').css(); $('ul').find('li');
有些函數(shù)是這樣使用的:
$('li').each(callback); $.each(lis,callback);
這里涉及到兩個概念:工具方法與實例方法。通常我們說的工具方法是指無需實例化就可以調(diào)用的函數(shù),如第一段代碼;實例方法是必須實例化對象以后才可以調(diào)用的函數(shù),如第二段代碼。jQuery中很多方法既是實例方法也是工具方法,只是調(diào)用方式略有不同,如第三段代碼。為了更清晰解釋JavaScript中的工具方法與實例方法,進(jìn)行如下測試。
function A(){ } A.prototype.fun_p=function(){console.log("prototpye");}; A.fun_c=function(){console.log("constructor");}; var a=new A(); A.fun_p();//A.fun_p is not a function A.fun_c();//constructor a.fun_p();//prototpye a.fun_c();//a.fun_c is not a function
通過以上測試可以得出結(jié)論,在原型中定義的是實例方法,在構(gòu)造函數(shù)中直接添加的是工具方法;實例方法不能由構(gòu)造函數(shù)調(diào)用,同理,工具方法也不能由實例調(diào)用。
當(dāng)然實例方法不僅可以在原型中定義,有以下三種定義方法:
function A(){ this.fun_f=function(){ console.log("Iam in the constructor"); }; } A.prototype.fun_p=function(){ console.log("Iam in the prototype"); }; var a=new A(); a.fun_f();//Iam in the constructor a.fun_i=function(){ console.log("Iam in the instance"); }; a.fun_i();//Iam in the instance a.fun_p();//Iam in the prototype
這三種方式的優(yōu)先級為:直接定義在實例上的變量的優(yōu)先級要高于定義在“this”上的,而定義在“this”上的又高于 prototype定義的變量。即直接定義在實例上的變量會覆蓋定義在“this”上和prototype定義的變量,定義在“this”上的會覆蓋prototype定義的變量。
下面看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 adeep copy situation if ( typeoftarget === "boolean" ) { deep= target; //Skip the boolean and the target target= arguments[ i ] || {}; i++; } // Handlecase when target is a string or something (possible in deep copy) if ( typeoftarget !== "object" && !jQuery.isFunction(target) ) { target= {}; } // ExtendjQuery itself if only one argument is passed if ( i ===length ) { 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; } } } } // Returnthe modified object return target; };
(1)首先,jQuery和其原型中extend()方法的實現(xiàn)使用的同一個函數(shù)。
(2)當(dāng)extend()中只有一個參數(shù)的時候,是為jQuery對象添加插件。在jQuery上擴(kuò)展的叫做工具方法,在jQuery.fn(jQuery原型)中擴(kuò)展的是實例方法,即使在jQuery和原型上擴(kuò)展相同名字的函數(shù)也可以,使用jQuery對象會調(diào)用工具方法,使用jQuery()會調(diào)用實例方法。
(3)當(dāng)extend()中有多個參數(shù)時,后面的參數(shù)都擴(kuò)展到第一個參數(shù)上。
var a={}; $.extend(a,{name:"hello"},{age:10}); console.log(a);//Object{name: "hello", age: 10}
(4)淺拷貝(默認(rèn)):
var a={}; varb={name:"hello"}; $.extend(a,b); console.log(a);//Object{name: "hello"} a.name="hi"; console.log(b);//Object{name: "hello"}
b不受a影響,但是如果b中一個屬性為對象:
var a={}; varb={name:{age:10}}; $.extend(a,b); console.log(a.name);//Object{age: 10} a.name.age=20; console.log(b.name);//Object{age: 20}
由于淺拷貝無法完成,則b.name會受到a的影響,這時我們往往希望深拷貝。
深拷貝:
var a={}; varb={name:{age:10}}; $.extend(true,a,b); console.log(a.name);//Object{age: 10} a.name.age=20; console.log(b.name);//Object{age: 10}
b.name不受a的影響。
var a={name:{job:"Web Develop"}}; var b={name:{age:10}}; $.extend(true,a,b); console.log(a.name);//age: 10 job: "Web Develop" //b.name沒有覆蓋a.name.job。
以上是“jQuery中extend()與工具方法、實例方法的示例分析”這篇文章的所有內(nèi)容,感謝各位的閱讀!希望分享的內(nèi)容對大家有幫助,更多相關(guān)知識,歡迎關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道!