首頁  >  文章  >  web前端  >  如何在實戰項目中使用JS深淺拷貝

如何在實戰項目中使用JS深淺拷貝

php中世界最好的语言
php中世界最好的语言原創
2018-06-09 11:52:071491瀏覽

這次帶給大家怎樣在實戰項目中使用JS深淺拷貝,怎樣在實戰項目中使用JS深淺拷貝的注意事項有哪些,下面就是實戰案例,一起來看一下。

本文實例講述了JavaScript深度拷貝和淺拷貝概念與用法。分享給大家供大家參考,具體如下:

js中的淺拷貝和深拷貝,只是針對複雜資料類型(ObjcetArray)的複製問題。簡單來講淺拷貝和深拷貝都可以實現在原有物件的基礎上再生成一份的作用。但是根據新產生的物件能否影響原始物件可以分為淺拷貝和深拷貝。

概念1:淺拷貝

淺拷貝就是指拷貝引用,新產生的引用和原來的引用都是指向同一個物件的實例,彼此之間的操作會相互影響。

概念2:深拷貝

在堆中重新開闢內存,把原引用對應的物件實例中所有的內容進行拷貝,因此保證了深拷貝的對象和原來的對像是完全隔離的,他們之間相互沒有影響。

概念3:數組深拷貝的實作

1. 使用for循環

<script type="text/javascript">
  var arr1=['a','b','c'];
  var arr2=[];
  function deepCopy(arr1,arr2){
    for(var i=0;i<arr1.length;i++){
      arr2[i]=arr1[i];
    }
  }
  deepCopy(arr1,arr2);
  arr2[1]=&#39;d&#39;;
  console.log(arr1);//[&#39;a&#39;,&#39;b&#39;,&#39;c&#39;]
  console.log(arr2);//[&#39;a&#39;,&#39;d&#39;,&#39;c&#39;]
</script>

2. 使用 slice()方法

<script type="text/javascript">
  var arr1=['a','b','c'];
  var arr2=arr1.slice(0);
  arr2[1]='d';
  console.log(arr1);//['a','b','c']
  console.log(arr2);//['a','d','c']
</script>

3. 使用concat方法

<script type="text/javascript">
    var arr1=['a','b','c'];
    var arr2=arr1.concat();
    arr2[1]='d';
    console.log(arr1);//['a','b','c']
    console.log(arr2);//['a','d','c']
</script>

概念4:物件的深拷貝

#1. 使用for循環

<script type="text/javascript">
  var obj = {
    name: 'FungLeo',
    sex: 'man',
    old: '18'
  }
  function copyObj(obj) {
    let res = {}
    for (var key in obj) {
      res[key] = obj[key]
    }
    return res
  }
  var obj2 = copyObj(obj);
  obj2["name"]="kka";
</script>

2. 借助JSON來實現

<script type="text/javascript">
  var obj = {
    name: 'FungLeo',
    sex: 'man',
    old: '18'
  }
  var obj2=JSON.parse(JSON.stringif(obj));
  obj2["name"]="kka";
</script>

相信看了本文案例你已經掌握了方法,更多精彩請關注php中文網其它相關文章!

推薦閱讀:

vue鷹架與vue-cli安裝

vue專案中watch的immediate使用

以上是如何在實戰項目中使用JS深淺拷貝的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn