本篇文章為大家展示了jQuery中extend()的作用是什么,內(nèi)容簡明扼要并且容易理解,絕對(duì)能使你眼前一亮,通過這篇文章的詳細(xì)介紹希望你能有所收獲。
成都創(chuàng)新互聯(lián)從2013年成立,是專業(yè)互聯(lián)網(wǎng)技術(shù)服務(wù)公司,擁有項(xiàng)目網(wǎng)站設(shè)計(jì)、成都網(wǎng)站建設(shè)網(wǎng)站策劃,項(xiàng)目實(shí)施與項(xiàng)目整合能力。我們以讓每一個(gè)夢(mèng)想脫穎而出為使命,1280元大方做網(wǎng)站,已為上家服務(wù),為大方各地企業(yè)和個(gè)人服務(wù),聯(lián)系電話:13518219792jquery是一個(gè)簡潔而快速的JavaScript庫,它具有獨(dú)特的鏈?zhǔn)秸Z法和短小清晰的多功能接口、高效靈活的css選擇器,并且可對(duì)CSS選擇器進(jìn)行擴(kuò)展、擁有便捷的插件擴(kuò)展機(jī)制和豐富的插件,是繼Prototype之后又一個(gè)優(yōu)秀的JavaScript代碼庫,能夠用于簡化事件處理、HTML文檔遍歷、Ajax交互和動(dòng)畫,以便快速開發(fā)網(wǎng)站。
jQuery extend()詳解及簡單實(shí)例
使用jQuery的時(shí)候會(huì)發(fā)現(xiàn),jQuery中有的函數(shù)是這樣使用的:
$.get(); $.post(); $.getJSON();
有些函數(shù)是這樣使用的:
$('div').css(); $('ul').find('li');
有些函數(shù)是這樣使用的:
$('li').each(callback); $.each(lis,callback);
這里涉及到兩個(gè)概念:工具方法與實(shí)例方法。通常我們說的工具方法是指無需實(shí)例化就可以調(diào)用的函數(shù),如第一段代碼;實(shí)例方法是必須實(shí)例化對(duì)象以后才可以調(diào)用的函數(shù),如第二段代碼。jQuery中很多方法既是實(shí)例方法也是工具方法,只是調(diào)用方式略有不同,如第三段代碼。為了更清晰解釋JavaScript中的工具方法與實(shí)例方法,進(jìn)行如下測(cè)試。
functionA(){ } 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
通過以上測(cè)試可以得出結(jié)論,在原型中定義的是實(shí)例方法,在構(gòu)造函數(shù)中直接添加的是工具方法;實(shí)例方法不能由構(gòu)造函數(shù)調(diào)用,同理,工具方法也不能由實(shí)例調(diào)用。
當(dāng)然實(shí)例方法不僅可以在原型中定義,有以下三種定義方法:
functionA(){ this.fun_f=function(){ console.log("Iam in the constructor"); }; } A.prototype.fun_p=function(){ console.log("Iam in the prototype"); }; var a=newA(); 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)先級(jí)為:直接定義在實(shí)例上的變量的優(yōu)先級(jí)要高于定義在“this”上的,而定義在“this”上的又高于 prototype定義的變量。即直接定義在實(shí)例上的變量會(huì)覆蓋定義在“this”上和prototype定義的變量,定義在“this”上的會(huì)覆蓋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()方法的實(shí)現(xiàn)使用的同一個(gè)函數(shù)。
(2)當(dāng)extend()中只有一個(gè)參數(shù)的時(shí)候,是為jQuery對(duì)象添加插件。在jQuery上擴(kuò)展的叫做工具方法,在jQuery.fn(jQuery原型)中擴(kuò)展的是實(shí)例方法,即使在jQuery和原型上擴(kuò)展相同名字的函數(shù)也可以,使用jQuery對(duì)象會(huì)調(diào)用工具方法,使用jQuery()會(huì)調(diào)用實(shí)例方法。
(3)當(dāng)extend()中有多個(gè)參數(shù)時(shí),后面的參數(shù)都擴(kuò)展到第一個(gè)參數(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中一個(gè)屬性為對(duì)象:
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會(huì)受到a的影響,這時(shí)我們往往希望深拷貝。
深拷貝:
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。
上述內(nèi)容就是jQuery中extend()的作用是什么,你們學(xué)到知識(shí)或技能了嗎?如果還想學(xué)到更多技能或者豐富自己的知識(shí)儲(chǔ)備,歡迎關(guān)注創(chuàng)新互聯(lián)網(wǎng)站建設(shè)公司行業(yè)資訊頻道。
另外有需要云服務(wù)器可以了解下創(chuàng)新互聯(lián)建站www.cdcxhl.com,海內(nèi)外云服務(wù)器15元起步,三天無理由+7*72小時(shí)售后在線,公司持有idc許可證,提供“云服務(wù)器、裸金屬服務(wù)器、高防服務(wù)器、香港服務(wù)器、美國服務(wù)器、虛擬主機(jī)、免備案服務(wù)器”等云主機(jī)租用服務(wù)以及企業(yè)上云的綜合解決方案,具有“安全穩(wěn)定、簡單易用、服務(wù)可用性高、性價(jià)比高”等特點(diǎn)與優(yōu)勢(shì),專為企業(yè)上云打造定制,能夠滿足用戶豐富、多元化的應(yīng)用場(chǎng)景需求。