關(guān)于extend的一些思考

JS 拷貝是一個(gè)在我們開(kāi)發(fā)中經(jīng)常遇到的一個(gè)問(wèn)題,我們通過(guò)使用extend這個(gè)函數(shù)來(lái)實(shí)現(xiàn)一些JS的復(fù)用。

比如下面的代碼:

var _default = { address: "上海市靜安區(qū)", sex: "男" };
var user = $.extend({}, _default,{name:"小亮", age:12});
console.log(user) //=> {name:"小亮", address: "上海市靜安區(qū)",age:12}

這是一個(gè)開(kāi)發(fā)中經(jīng)常遇到的一個(gè)場(chǎng)景,我們通過(guò)復(fù)用一些默認(rèn)的配置,減少了代碼開(kāi)發(fā)量。這里我是用的$.extend是jQuery提供的一個(gè)靜態(tài)拷貝函數(shù)。它在這里的作用就是把_default 和 {name:"小亮",age:12}的屬性合并到 {} 中,并且返回。

自己如何實(shí)現(xiàn)

作為一個(gè)程序員,我們不僅僅需要知其然,還是知其所以然,所以我們不僅是需要知道怎么使用,也需要明白其中的實(shí)現(xiàn)和原理,以及一些我們需要注意的事項(xiàng)。

第一步: 入口參數(shù)處理

extend = function (x, y, z, ......) { ...... }

extend這個(gè)函數(shù)的功能是把除第一個(gè)參數(shù)外,其它參數(shù)的屬性合并到第一個(gè)參數(shù),那我們是不知道總共有多少個(gè)參數(shù),所以我們需要使用到 arguments 這個(gè)對(duì)象去獲取參數(shù),當(dāng)然了,如果是在ES6的情況下,我們就不需要使用arguments這個(gè)參數(shù)對(duì)象了。

extend = function (x, y, z, ......) { console.log(arguments) //=> [x,y,z ......] console.log(arguments[0]) //=> x console.log(arguments[1]) //=> y ...... }

這里arguments 是一個(gè)類(lèi)數(shù)組對(duì)象,可以通過(guò)arguments的下標(biāo)獲取相關(guān)的參數(shù)值,但是沒(méi)有實(shí)現(xiàn)數(shù)組相關(guān)的方法。所以,我們有時(shí)候需要把a(bǔ)rguments這個(gè)參數(shù)對(duì)象轉(zhuǎn)化為數(shù)組。

var argus = Array.prototype.slice.call(arguments);

這樣我們就能夠獲取extend函數(shù)的不定參數(shù)

第二步: 數(shù)據(jù)拷貝

在開(kāi)始進(jìn)行數(shù)據(jù)拷貝之前,我們應(yīng)該需要確認(rèn)兩個(gè)問(wèn)題。

  1. 我們獲取到參數(shù)以后,第一個(gè)參數(shù),應(yīng)該是作為我們的base對(duì)象,后面的對(duì)象把他們的屬性放到這個(gè)base對(duì)象上,而且是依次執(zhí)行的。 這樣的話(huà),后面屬性值會(huì)把前面的屬性值給進(jìn)行覆蓋。

  2. 就是需要對(duì)參數(shù)類(lèi)型進(jìn)行判斷, 按照日常的開(kāi)發(fā)需求來(lái)說(shuō),我們這里是只需要純 Object 對(duì)象,那么像Number,Boolean,String,F(xiàn)unction, Array...... 這種如果出現(xiàn)在參數(shù)里面。那么從功能角度來(lái)說(shuō),這些數(shù)據(jù)是無(wú)用數(shù)據(jù),所以這些數(shù)據(jù)會(huì)被過(guò)濾掉。

Object.prototype.toString.call(obj) === "[object Object]" //=> true

那么我們開(kāi)始進(jìn)入正題,實(shí)現(xiàn)extend的拷貝

var isObj = function (obj) { return Object.prototype.toString.call(obj) === "[object Object]"; };
var extend = function(base) { // argus 表示除 base 后面的列表集合 var argus = Array.prototype.slice.call(arguments,1),obj,key; base = isObj(base) ? base : {}; for (var index = 0, length = argus.length; index < length; index++) { obj = argus[index]; if (isObj(obj)) { // 防止非純Object對(duì)象 for (key in obj) { if (obj.hasOwnProperty(key)) { base[key] = obj[key]; } } } } return base; }

測(cè)試用例

extend({},{a:1},{b:1}); //=> Object {a: 1, b: 1}
extend({a:1},{b:1}); //=> Object {a:1, b:1}
extend({},[1,2,3]); //=> Object {}
extend({},{aa : function() { alert("aa")}}); //=>Object{aa:()}
extend(null,{aa : 111 }); //=>Object{aa :111}

到此,我們已經(jīng)完成了 extend 這個(gè)函數(shù)基本骨架。

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
平臺(tái)聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀(guān)點(diǎn),簡(jiǎn)書(shū)系信息發(fā)布平臺(tái),僅提供信息存儲(chǔ)服務(wù)。
  • 序言:七十年代末,一起剝皮案震驚了整個(gè)濱河市,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌,老刑警劉巖,帶你破解...
    沈念sama閱讀 230,247評(píng)論 6 543
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場(chǎng)離奇詭異,居然都是意外死亡,警方通過(guò)查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 99,520評(píng)論 3 429
  • 文/潘曉璐 我一進(jìn)店門(mén),熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái),“玉大人,你說(shuō)我怎么就攤上這事。” “怎么了?”我有些...
    開(kāi)封第一講書(shū)人閱讀 178,362評(píng)論 0 383
  • 文/不壞的土叔 我叫張陵,是天一觀(guān)的道長(zhǎng)。 經(jīng)常有香客問(wèn)我,道長(zhǎng),這世上最難降的妖魔是什么? 我笑而不...
    開(kāi)封第一講書(shū)人閱讀 63,805評(píng)論 1 317
  • 正文 為了忘掉前任,我火速辦了婚禮,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘。我一直安慰自己,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 72,541評(píng)論 6 412
  • 文/花漫 我一把揭開(kāi)白布。 她就那樣靜靜地躺著,像睡著了一般。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上,一...
    開(kāi)封第一講書(shū)人閱讀 55,896評(píng)論 1 328
  • 那天,我揣著相機(jī)與錄音,去河邊找鬼。 笑死,一個(gè)胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播,決...
    沈念sama閱讀 43,887評(píng)論 3 447
  • 文/蒼蘭香墨 我猛地睜開(kāi)眼,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼!你這毒婦竟也來(lái)了?” 一聲冷哼從身側(cè)響起,我...
    開(kāi)封第一講書(shū)人閱讀 43,062評(píng)論 0 290
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤,失蹤者是張志新(化名)和其女友劉穎,沒(méi)想到半個(gè)月后,有當(dāng)?shù)厝嗽跇?shù)林里發(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 49,608評(píng)論 1 336
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 41,356評(píng)論 3 358
  • 正文 我和宋清朗相戀三年,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 43,555評(píng)論 1 374
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情,我是刑警寧澤,帶...
    沈念sama閱讀 39,077評(píng)論 5 364
  • 正文 年R本政府宣布,位于F島的核電站,受9級(jí)特大地震影響,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 44,769評(píng)論 3 349
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧,春花似錦、人聲如沸。這莊子的主人今日做“春日...
    開(kāi)封第一講書(shū)人閱讀 35,175評(píng)論 0 28
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)。三九已至,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背。 一陣腳步聲響...
    開(kāi)封第一講書(shū)人閱讀 36,489評(píng)論 1 295
  • 我被黑心中介騙來(lái)泰國(guó)打工, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人。 一個(gè)月前我還...
    沈念sama閱讀 52,289評(píng)論 3 400
  • 正文 我出身青樓,卻偏偏與公主長(zhǎng)得像,于是被迫代替她去往敵國(guó)和親。 傳聞我的和親對(duì)象是個(gè)殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 48,516評(píng)論 2 379

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

  • 工廠(chǎng)模式類(lèi)似于現(xiàn)實(shí)生活中的工廠(chǎng)可以產(chǎn)生大量相似的商品,去做同樣的事情,實(shí)現(xiàn)同樣的效果;這時(shí)候需要使用工廠(chǎng)模式。簡(jiǎn)單...
    舟漁行舟閱讀 7,805評(píng)論 2 17
  • 單例模式 適用場(chǎng)景:可能會(huì)在場(chǎng)景中使用到對(duì)象,但只有一個(gè)實(shí)例,加載時(shí)并不主動(dòng)創(chuàng)建,需要時(shí)才創(chuàng)建 最常見(jiàn)的單例模式,...
    Obeing閱讀 2,091評(píng)論 1 10
  • 三、閉包和高階函數(shù) 3.1 閉包 3.1.1 變量的作用域 所謂變量的作用域,就是變量的有效范圍。通過(guò)作用域的劃分...
    梁同學(xué)de自言自語(yǔ)閱讀 1,480評(píng)論 0 6
  • @轉(zhuǎn)自GitHub 介紹js的基本數(shù)據(jù)類(lèi)型。Undefined、Null、Boolean、Number、Strin...
    YT_Zou閱讀 1,184評(píng)論 0 0
  • 我總是給最?lèi)?ài)自己的人傷害, 又總是在突然失去愛(ài)后懊悔不已,原來(lái)愛(ài)很簡(jiǎn)單 以愛(ài)之名,他最近看起來(lái)又添上了幾縷銀絲,好...
    木子口兒閱讀 408評(píng)論 0 0