溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊(cè)×
其他方式登錄
點(diǎn)擊 登錄注冊(cè) 即表示同意《億速云用戶(hù)服務(wù)條款》

JS中淺度克隆和深度克隆的區(qū)別是什么

發(fā)布時(shí)間:2020-09-15 09:33:52 來(lái)源:億速云 閱讀:229 作者:小新 欄目:web開(kāi)發(fā)

小編給大家分享一下JS中淺度克隆和深度克隆的區(qū)別是什么,希望大家閱讀完這篇文章后大所收獲,下面讓我們一起去探討吧!

JavaScript中克隆分為兩種:淺度克隆和深度克隆,都是先對(duì)值遍歷一遍判斷是原始值還是引用值,原始值直接復(fù)制,引用值先判斷是對(duì)象還是數(shù)組再進(jìn)行克隆

原始值:像Undefined,Null,Boolean,Number和String值被稱(chēng)為原始值

引用值:像對(duì)象數(shù)組函數(shù)等值稱(chēng)為引用值

淺度克隆

主要是將數(shù)據(jù)的地址賦給對(duì)應(yīng)的變量但并沒(méi)有將具體的值賦值給對(duì)應(yīng)的變量,變量會(huì)隨著數(shù)據(jù)的改變而改變

 <script>
    var obj={
      name:"張三",
      age:18,
      sex:"male",
       grade:[' Math:90','English:88','Chinese:80']
    }
    var obj1={}
    function clone(origin,target){
      var target=target||{};
      for(var prop in origin){
        target[prop]=origin[prop];
      }//防止用戶(hù)不傳target對(duì)象,給了參數(shù)就直接用,不給就當(dāng)空對(duì)象,
     return target;
    }
    clone(obj,obj1);
  </script>

結(jié)果

JS中淺度克隆和深度克隆的區(qū)別是什么

obj1將obj的值克隆過(guò)來(lái)了,當(dāng)給obj的grade添加值時(shí),obj1的grade的值也隨之改變了

深度克隆

是將數(shù)據(jù)賦值給相對(duì)應(yīng)的變量,所以產(chǎn)生了一個(gè)新的數(shù)據(jù)也就有了新的地址,原數(shù)據(jù)的改變不會(huì)影響新數(shù)據(jù)

<script type="text/javascript">
var obj={
      name:"張三",
      age:18,
      sex:"male",
       grade:[' Math:90','English:88','Chinese:80']
    }
    var obj1={}
    function deepClone(origin,target){
	var target=target||{},
	toStr=Object.prototype.toString,//簡(jiǎn)化代碼
	arrStr="[Object Array]";
	for(var prop in origin){//從原始 origin 拷貝到 target
    		if(origin.hasOwnProperty(prop)){///先判斷是不是原型上的屬性,如果是false 就是原型上的
    	   {
      	if(typeof(origin[prop])!== "null" && typeof (origin[prop]) =='object')
      	{
    			if(toStr.call(origin[prop])==arrStr){
    				target[prop]=[];
    			}//數(shù)組對(duì)象
    			else{
    				target[prop]={};
    			}//對(duì)象
//
    			deepClone(origin[prop],target[prop]);
    		}
    		else{
    			target[prop]=origin[prop];
    		}
    	}
    }
     return target;
 }
	</script>

結(jié)果

JS中淺度克隆和深度克隆的區(qū)別是什么

obj1將obj的值克隆過(guò)來(lái)了,當(dāng)給obj的grade添加值時(shí),obj1的grade的值不會(huì)改變

看完了這篇文章,相信你對(duì)JS中淺度克隆和深度克隆的區(qū)別是什么有了一定的了解,想了解更多相關(guān)知識(shí),歡迎關(guān)注億速云行業(yè)資訊頻道,感謝各位的閱讀!

向AI問(wèn)一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀(guān)點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI