jQuery.extend和jQuery.fn.extend

jQuery.extend簡(jiǎn)單分析

jQuery.extend = jQuery.fn.extend = function() {
    var options, name, src, copy, copyIsArray, clone,
        target = arguments[ 0 ] || {},//把第一個(gè)參數(shù)賦值給target
        i = 1, //從第幾個(gè)參數(shù)開始向target對(duì)象合并
        length = arguments.length,//傳入?yún)?shù)的個(gè)數(shù)
        deep = false;//是否進(jìn)行深復(fù)制

    // Handle a deep copy situation處理深復(fù)制的情況
    if ( typeof target === "boolean" ) {
        deep = target;

        // Skip the boolean and the target如果一個(gè)參數(shù)為布爾值温自,判斷時(shí)候進(jìn)行深復(fù)制,target跳過(guò)第一個(gè)參數(shù)
        target = arguments[ i ] || {};
        i++;
    }

    // Handle case when target is a string or something (possible in deep copy)
    if ( typeof target !== "object" && !jQuery.isFunction( target ) ) {
        target = {}; //如果target不是一個(gè)對(duì)象也不是函數(shù),
    }

    // Extend jQuery itself if only one argument is passed
    // 如果只有一個(gè)參數(shù),把jQuery或jQuery.fn本身作為target锌妻,把參數(shù)對(duì)象合并到j(luò)Query或jQuery.fn中區(qū)
    // 如果有多個(gè)對(duì)象參數(shù),則是把后面的對(duì)象合并到第一個(gè)對(duì)象中去(這里假設(shè)沒(méi)有deep參數(shù))
    if ( i === length ) {
        target = this;
        i--;
    }

    for ( ; i < length; i++ ) {

        // Only deal with non-null/undefined values
        // 只有當(dāng)參數(shù)的值不是null的時(shí)候才進(jìn)行處理
        if ( ( options = arguments[ i ] ) != null ) {

            // Extend the base object
            for ( name in options ) {//遍歷options中的屬性
                src = target[ name ];
                copy = options[ name ];

                // Prevent never-ending loop
                // 防止死循環(huán),比如extend(true, target, {'target':target});
                if ( target === copy ) {
                    continue;
                }

                // Recurse if we're merging plain objects or arrays
                if ( deep && copy && ( jQuery.isPlainObject( copy ) ||
                    ( copyIsArray = jQuery.isArray( copy ) ) ) ) {
                    //deep值為true,copy存在并且是個(gè)存粹的對(duì)象或者一個(gè)數(shù)組的時(shí)候進(jìn)行深復(fù)制
                    if ( copyIsArray ) {
                        //數(shù)組
                        copyIsArray = false;
                        clone = src && jQuery.isArray( src ) ? src : [];

                    } else {
                        //存粹對(duì)象
                        clone = src && jQuery.isPlainObject( src ) ? src : {};
                    }

                    // Never move original objects, clone them
                    // 遞歸調(diào)用垮耳,吧copy復(fù)制給clone
                    target[ name ] = jQuery.extend( deep, clone, copy );

                // Don't bring in undefined values
                // 其他不知undefined的值
                } else if ( copy !== undefined ) {
                    target[ name ] = copy;
                }
            }
        }
    }

    // Return the modified object
    return target;
};

jQuery.extend ()

  • 第一個(gè)參數(shù)如果是布爾值,則用來(lái)判斷是否進(jìn)行深復(fù)制
  • 如果只傳入一個(gè)對(duì)象遂黍,那么就把這個(gè)對(duì)象復(fù)制給全局對(duì)象
  • 如果傳入多個(gè)對(duì)象 终佛,那么就是吧后面幾個(gè)對(duì)象的值復(fù)制給第一個(gè)對(duì)象

jQuery.extend是復(fù)制給全局對(duì)象
jQuery.fn.extend是復(fù)制給jQuery的原型

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個(gè)濱河市妓湘,隨后出現(xiàn)的幾起案子查蓉,更是在濱河造成了極大的恐慌,老刑警劉巖榜贴,帶你破解...
    沈念sama閱讀 216,591評(píng)論 6 501
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件豌研,死亡現(xiàn)場(chǎng)離奇詭異,居然都是意外死亡唬党,警方通過(guò)查閱死者的電腦和手機(jī)鹃共,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,448評(píng)論 3 392
  • 文/潘曉璐 我一進(jìn)店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái)驶拱,“玉大人霜浴,你說(shuō)我怎么就攤上這事±陡伲” “怎么了阴孟?”我有些...
    開封第一講書人閱讀 162,823評(píng)論 0 353
  • 文/不壞的土叔 我叫張陵晌纫,是天一觀的道長(zhǎng)。 經(jīng)常有香客問(wèn)我永丝,道長(zhǎng)锹漱,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 58,204評(píng)論 1 292
  • 正文 為了忘掉前任慕嚷,我火速辦了婚禮哥牍,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘喝检。我一直安慰自己嗅辣,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,228評(píng)論 6 388
  • 文/花漫 我一把揭開白布挠说。 她就那樣靜靜地躺著澡谭,像睡著了一般。 火紅的嫁衣襯著肌膚如雪纺涤。 梳的紋絲不亂的頭發(fā)上译暂,一...
    開封第一講書人閱讀 51,190評(píng)論 1 299
  • 那天,我揣著相機(jī)與錄音撩炊,去河邊找鬼外永。 笑死,一個(gè)胖子當(dāng)著我的面吹牛拧咳,可吹牛的內(nèi)容都是我干的伯顶。 我是一名探鬼主播,決...
    沈念sama閱讀 40,078評(píng)論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼骆膝,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼祭衩!你這毒婦竟也來(lái)了?” 一聲冷哼從身側(cè)響起阅签,我...
    開封第一講書人閱讀 38,923評(píng)論 0 274
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤掐暮,失蹤者是張志新(化名)和其女友劉穎,沒(méi)想到半個(gè)月后政钟,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體路克,經(jīng)...
    沈念sama閱讀 45,334評(píng)論 1 310
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,550評(píng)論 2 333
  • 正文 我和宋清朗相戀三年养交,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了精算。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 39,727評(píng)論 1 348
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡碎连,死狀恐怖灰羽,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情,我是刑警寧澤廉嚼,帶...
    沈念sama閱讀 35,428評(píng)論 5 343
  • 正文 年R本政府宣布玫镐,位于F島的核電站,受9級(jí)特大地震影響怠噪,放射性物質(zhì)發(fā)生泄漏摘悴。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,022評(píng)論 3 326
  • 文/蒙蒙 一舰绘、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧葱椭,春花似錦捂寿、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,672評(píng)論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)。三九已至治笨,卻和暖如春驳概,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背旷赖。 一陣腳步聲響...
    開封第一講書人閱讀 32,826評(píng)論 1 269
  • 我被黑心中介騙來(lái)泰國(guó)打工顺又, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人等孵。 一個(gè)月前我還...
    沈念sama閱讀 47,734評(píng)論 2 368
  • 正文 我出身青樓稚照,卻偏偏與公主長(zhǎng)得像,于是被迫代替她去往敵國(guó)和親俯萌。 傳聞我的和親對(duì)象是個(gè)殘疾皇子果录,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 44,619評(píng)論 2 354

推薦閱讀更多精彩內(nèi)容

  • jQuery為開發(fā)插件提拱了兩個(gè)方法,分別是: jQuery.fn.extend(); jQuery.extend...
    Jsolo閱讀 1,204評(píng)論 0 6
  • 1.JQuery 基礎(chǔ) 改變web開發(fā)人員創(chuàng)造搞交互性界面的方式咐熙。設(shè)計(jì)者無(wú)需花費(fèi)時(shí)間糾纏JS復(fù)雜的高級(jí)特性弱恒。 1....
    LaBaby_閱讀 1,335評(píng)論 0 2
  • 1.JQuery 基礎(chǔ) 改變web開發(fā)人員創(chuàng)造搞交互性界面的方式。設(shè)計(jì)者無(wú)需花費(fèi)時(shí)間糾纏JS復(fù)雜的高級(jí)特性棋恼。 1....
    LaBaby_閱讀 1,171評(píng)論 0 1
  • 引子 jQurey 提供了兩種方法擴(kuò)張方式返弹,分別為 jQuery.fn.extend(object)和jQuery...
    Lemon不怕酸啊閱讀 305評(píng)論 0 1
  • 原文鏈接 http://blog.poetries.top/2016/10/20/review-jQuery 關(guān)注...
    程序員poetry閱讀 16,643評(píng)論 18 503