如何在JavaScript中使用深拷貝和淺拷貝?針對這個問題,這篇文章詳細介紹了相對應的分析和解答,希望可以幫助更多想解決這個問題的小伙伴找到更簡單易行的方法。
1.JavaScript主要用來向HTML頁面添加交互行為。 2.JavaScript可以直接嵌入到HTML頁面,但寫成單獨的js文件有利于結構和行為的分離。 3.JavaScript具有跨平臺特性,在絕大多數瀏覽器的支持下,可以在多種平臺下運行。
概念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]='d';
console.log(arr1);//['a','b','c']
console.log(arr2);//['a','d','c']
</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>關于如何在JavaScript中使用深拷貝和淺拷貝問題的解答就分享到這里了,希望以上內容可以對大家有一定的幫助,如果你還有很多疑惑沒有解開,可以關注億速云行業資訊頻道了解更多相關知識。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。