ホームページ >ウェブフロントエンド >jsチュートリアル >JavaScriptの配列コピーの詳しい説明

JavaScriptの配列コピーの詳しい説明

高洛峰
高洛峰オリジナル
2017-02-03 13:38:001695ブラウズ

前の言葉

オブジェクトのコピーについては、前回のブログ記事で紹介しました

push

function copyArray(arr){
  var result = [];
  for(var i = 0; i < arr.length; i++){
    result.push(arr[i]);
  }
  return result;
}
 
var obj1=[1,2,3];
var obj2=copyArray(obj1);
console.log(obj1); //[1,2,3]
console.log(obj2); //[1,2,3]
obj2.push(4);
console.log(obj1); //[1,2,3]
console.log(obj2); //[1,2,3,4]

join
この方法を使用する欠点は、配列内のすべての項目がstrings

function copyArray(arr){
  var result = [];
  result = arr.join().split(&#39;,&#39;);
  return result;
}
 
var obj1=[1,2,3];
var obj2=copyArray(obj1);
console.log(obj1); //[1,2,3]
console.log(obj2); //[&#39;1&#39;,&#39;2&#39;,&#39;3&#39;]
obj2.push(4);
console.log(obj1); //[1,2,3]
console.log(obj2); //[&#39;1&#39;,&#39;2&#39;,&#39;3&#39;,4]

concat

function copyArray(arr){
  var result = [];
  result = arr.concat();
  return result;
}
 
var obj1=[1,2,3];
var obj2=copyArray(obj1);
console.log(obj1); //[1,2,3]
console.log(obj2); //[1,2,3]
obj2.push(4);
console.log(obj1); //[1,2,3]
console.log(obj2); //[1,2,3,4]

slice

function copyArray(arr){
  var result = [];
  result = arr.slice();
  return result;
}
 
var obj1=[1,2,3];
var obj2=copyArray(obj1);
console.log(obj1); //[1,2,3]
console.log(obj2); //[1,2,3]
obj2.push(4);
console.log(obj1); //[1,2,3]
console.log(obj2); //[1,2,3,4]

ディープコピー

ディープコピーを実装したい場合、上記のメソッドは配列の浅いコピーのみを実装します。のコピーarray 、再帰メソッドを使用する必要があります

function copyArray(arr,result){
  var result = result || [];
  for(var i = 0; i < arr.length; i++){
    if(arr[i] instanceof Array){
      result[i] = [];
      copyArray(arr[i],result[i]);
    }else{
      result[i] = arr[i];
    }     
  }
  return result;
}
 
var obj1=[1,2,[3,4]];
var obj2=copyArray(obj1);
console.log(obj1[2]); //[3,4]
console.log(obj2[2]); //[3,4]
obj2[2].push(5);
console.log(obj1[2]); //[3,4]
console.log(obj2[2]); //[3,4,5]

JavaScript 配列のコピーの詳細な説明と関連記事については、PHP 中国語 Web サイトに注目してください。


声明:
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。