91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

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

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

怎么在JavaScript中引用vs復制

發布時間:2021-04-14 18:08:28 來源:億速云 閱讀:177 作者:Leah 欄目:web開發

本篇文章為大家展示了怎么在JavaScript中引用vs復制,內容簡明扼要并且容易理解,絕對能使你眼前一亮,通過這篇文章的詳細介紹希望你能有所收獲。

let age = 18;
let age2 = age;
console.log(age, age2);

我們會得到以下的值:

18 18

這個相信大家都能很好理解。

那么如果我們改變 age 的值呢?輸出會有什么變化?

age = 20;
console.log(age, age2);

我們會得到:

20 18

看到這里大家就奇怪了,上面的結果都很正常啊。

但在 JavaScript 中是有例外的,對于普通數據類型如 integer,string,boolean 可以通過 = 來復制這個變量,但對于 array 和 object 數據類型,= 只能起到引用的效果。

大家可以看下面這個例子:

let arr = ['wes', 'bob', 'faker'];
let arr2 = arr;
console.log(arr2, arr);
arr[2] = 'dean';
console.log(arr2, arr);

得到的結果是:

["wes", "bob", "faker"] ["wes", "bob", "faker"]
["wes", "bob", "dean"] ["wes", "bob", "dean"]

我們會發現隨著 arr 的改變,arr2 也會跟著改變。

說明 arr2 并沒有復制 arr 的值,只是引用了它,它們都指向同一個內存中的值。

object 也是一樣的:

let obj = {
 age: 19,
 name: 'like',
 last: 'jam'
};
let obj2 = obj;
console.log(obj, obj2);
obj.age = 50;
console.log(obj, obj2);

得到的結果是:

{age: 19, name: "like", last: "jam"} {age: 19, name: "like", last: "jam"}
{age: 50, name: "like", last: "jam"} {age: 50, name: "like", last: "jam"}

那么如何復制 array 和 object 呢?

復制 array 的方法:

方法1:

let arr2 = [].concat(arr);

方法2:

let arr2 = arr.slice();

方法3:

let arr2 = Array.from(arr);

方法4:

let arr2 = [...arr];

一般我們比較常用的是方法3和方法4,方法1和方法2比較取巧,但都是可以達到復制 array 的目的的。

ps: [...arr] 是 ES6 中的方法。

復制 object 的方法:

方法1:

let obj2 = Object.assign({}, obj);

方法2:

let obj2 = {...obj};

方法1和方法2都有個缺點,它們只會復制對象的第一層。

看下面這個例子:

let obj = {
 number: 12,
 name: {
  first: 'bob',
  last: 'evil'
 }
};
let obj2 = Object.assign({}, obj);
obj.number = 50;
console.log(obj, obj2);

我們會得到下面的結果:

obj = {
    number: 50,
    name: {
        first: 'bob',
        last: 'evil'
    }
}

obj2 = {
    number: 12,
    name: {
        first: 'bob',
        last: 'evil'
    }
}

但如果我們改變第二層的值:

obj.name.first = 'sam';
console.log(obj, obj2);

obj = {
    number: 50,
    name: {
        first: 'sam',
        last: 'evil'
    }
}

obj2 = {
    number: 12,
    name: {
        first: 'sam',
        last: 'evil'
    }
}

上述內容就是怎么在JavaScript中引用vs復制,你們學到知識或技能了嗎?如果還想學到更多技能或者豐富自己的知識儲備,歡迎關注億速云行業資訊頻道。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

福建省| 孟村| 西藏| 通州市| 屏东市| 铜川市| 绩溪县| 万山特区| 桐柏县| 惠来县| 拉萨市| 常熟市| 邯郸市| 秭归县| 兰西县| 遂平县| 涪陵区| 齐齐哈尔市| 茂名市| 隆安县| 江源县| 静安区| 阿拉善右旗| 横峰县| 旅游| 旬阳县| 尉氏县| 承德县| 手游| 蓬溪县| 高要市| 车致| 错那县| 友谊县| 彭水| 大渡口区| 阿勒泰市| 买车| 郸城县| 收藏| 麻城市|