javascript深拷貝的原理與實現(xiàn)方法分析
本文實例講述了javascript深拷貝的原理與實現(xiàn)方法。分享給大家供大家參考,具體如下:
要講JavaScript的拷貝,就得先講講javascript中的值傳遞和引用傳遞。
javascript中沒有一個具體的語法來規(guī)定哪些參數(shù)是引用傳遞,而其他語言中都有明文規(guī)定,比如 C# 中的 ref 和 PHP 中的 & 。
這也是javascript眾多弊端中的一個。
我們先看看下面這段代碼:
//值傳遞 var i = 3; var j = i; j = 4; document.write(i);//3 //引用傳遞 var m = [1]; var n = m; n[0] = 2; document.write(n[0]);//2
說明,javascript中只有簡單類型是值傳遞,而其他復(fù)雜類型比如數(shù)組、對象都是默認(rèn)就是引用傳遞的。
那么我們?nèi)绻枰獜?fù)制一個對象呢?就必須自己定義方法:
//深度拷貝函數(shù),其實就是值傳遞 function cloneObject(srcobj){ var tarobj=new Object(); for(var key in srcobj){//判斷對象中是否繼續(xù)為對象 tarobj[key]=typeof srcobj[key]==='object'?cloneObject(srcobj[key]):srcobj[key]; } return tarobj; } //驗證深度拷貝函數(shù)的使用 // 測試用例: var srcObj = { a: 1, b: { b1: ["hello", "hi"], b2: "JavaScript" } }; var abObj = srcObj;//引用傳遞 var tarObj = cloneObject(srcObj); srcObj.a = 2; srcObj.b.b1[0] = "Hello"; console.log(abObj.a);//2 console.log(abObj.b.b1[0]);//Hello,說明普通的=是一種引用傳遞 console.log(tarObj.a); // 1 console.log(tarObj.b.b1[0]); // "hello",說明我們定義的深拷貝是值傳遞
其實就是通過實例化一個新的對象,從而在堆中開辟一塊新的內(nèi)存空間,使得棧中的變量名指向堆中的新內(nèi)容。
更多關(guān)于JavaScript相關(guān)內(nèi)容可查看本站專題:《javascript面向?qū)ο笕腴T教程》、《JavaScript中json操作技巧總結(jié)》、《JavaScript切換特效與技巧總結(jié)》、《JavaScript查找算法技巧總結(jié)》、《JavaScript動畫特效與技巧匯總》、《JavaScript錯誤與調(diào)試技巧總結(jié)》、《JavaScript數(shù)據(jù)結(jié)構(gòu)與算法技巧總結(jié)》、《JavaScript遍歷算法與技巧總結(jié)》及《JavaScript數(shù)學(xué)運(yùn)算用法總結(jié)》
希望本文所述對大家JavaScript程序設(shè)計有所幫助。
相關(guān)文章
IE9+已經(jīng)不對document.createElement向下兼容的解決方法
這篇文章主要介紹了IE9+已經(jīng)不對document.createElement向下兼容的解決方法,需要的朋友可以參考下2015-09-09一文詳解如何使npm-scripts更好維護(hù)的配置方法
這篇文章主要為大家介紹了如何使npm-scripts更好維護(hù)的配置方法詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2023-06-06JavaScript 獲取/設(shè)置光標(biāo)位置,兼容Input&&TextArea
JavaScript 獲取/設(shè)置光標(biāo)位置,兼容Input&&TextArea:項目中遇到的問題,特此記錄。2011-01-01使用javascript實現(xiàn)Iframe自適應(yīng)高度
這篇文章主要介紹了使用javascript實現(xiàn)Iframe自適應(yīng)高度,需要的朋友可以參考下2014-12-12利用JS測試目標(biāo)網(wǎng)站的打開響應(yīng)速度
本文簡單說明利用JS來測試目標(biāo)網(wǎng)站的打開響應(yīng)速度,方法簡單明了大家一看就明白并附上了腳本源碼2017-12-12