摘要:引用和值拷貝微信公眾號開發(fā)企業(yè)級產(chǎn)品全棧開發(fā)速成周末班首期班號正式開班,歡迎搶座作者黎躍春追時間的人簡介是推出的一個天挑戰(zhàn)。深拷貝與淺拷貝對比創(chuàng)建對象黎躍春淺拷貝深拷貝將對象轉(zhuǎn)換成字符串,打印時效果清晰。
Day14 - JavaScript 引用和值拷貝
(Node+Vue+微信公眾號開發(fā))企業(yè)級產(chǎn)品全棧開發(fā)速成周末班首期班(10.28號正式開班,歡迎搶座)
項目效果 按值操作作者:?黎躍春-追時間的人
簡介:JavaScript30 是 Wes Bos 推出的一個 30 天挑戰(zhàn)。項目免費提供了 30 個視頻教程、30 個挑戰(zhàn)的起始文檔和 30 個挑戰(zhàn)解決方案源代碼。目的是幫助人們用純 JavaScript 來寫東西,不借助框架和庫,也不使用編譯器和引用?,F(xiàn)在你看到的是這系列指南的第 14 篇。完整中文版指南及視頻教程在 從零到壹全棧部落。
基本類型由值操作。以下類型在JavaScript中被視為基本類型:
String
Number
Boolean
Null
Undefined
基本數(shù)據(jù)類型賦值你可以理解成值拷貝,從深拷貝和淺拷貝的角度去思考的話,你可以理解成深拷貝,當你修改一個變量的值時,不會影響其他變量的值。
實例let age = 100; let age2 = age; console.log(age, age2); age = 200; console.log(age, age2); let name = "liyuechun"; let name2 = name; console.log(name, name2); name = "liyc"; console.log(name, name2);
由此可見,基本類型,按值操作,新建的變量會將值復制給新的變量,各自的改變不會互相影響。
對象Object類型是按引用操作的,如果它不是基本類型中的一個,那么它就是對象,這里如果我們細究的話,JavaScript中每一個東西都可以當做對象,甚至是基本的類型(不包括null和undefined),但我們盡量不要鉆這個牛角尖。
一些JavaScript中的對象:
Object
Function
Array
Set
Map
淺拷貝const players = ["Wes", "Sarah", "Ryan", "Poppy"]; // 引用拷貝 const team = players; console.log(`players: ${players}`, `team:${team}`); // 我們做如下操作: team[3] = "Lux"; console.log(`players: ${players}`, `team:${team}`); const team2 = players.slice(); console.log(`players: ${players}`, `team:${team}`, `team2:${team2}`);
由上效果顯示,淺拷貝拷貝的是指針,當你去操作一個指針時,其實所有指針指向的同一個對象的值都會發(fā)生變化。
深拷貝const players = ["Wes", "Sarah", "Ryan", "Poppy"]; // 創(chuàng)建新數(shù)組并且將原來的數(shù)組拼接到新數(shù)組中 const team3 = [].concat(players); // ES6 Spread語法 const team4 = [...players]; team4[3] = "heeee hawww"; console.log(`team4:${team4}`); const team5 = Array.from(players); console.log(`team5:${team5}`);
由上面的效果顯示,但我們修改team4時,players并沒有發(fā)生任何變化,上面的contact,...,Array.from都屬于深拷貝,會將原來的內(nèi)容重新拷貝一份,所以當你操作一個指針時不會影響原對象。
深拷貝 與 淺拷貝對比//創(chuàng)建object對象 const person = { name: "黎躍春", age: 29 }; // 淺拷貝 console.log(`person:${JSON.stringify(person)}`); const captain = person; captain.number = 99; console.log(`person:${JSON.stringify(person)}`); console.log(`captain:${JSON.stringify(captain)}`); // 深拷貝 const cap2 = Object.assign({}, person, { number: 99, age: 12 }); console.log(`cap2:${JSON.stringify(cap2)}`); console.log(`person:${JSON.stringify(person)}`);
JSON.stringify將對象轉(zhuǎn)換成字符串,打印時效果清晰。
captain = person屬于淺拷貝
Object.assign的三個參數(shù)中,第一個參數(shù)屬于初始值,它最終的值是第二個和第三個參數(shù)的并集,如果第二個、第三個參數(shù)有相同的屬性,那個第三個參數(shù)會覆蓋第二個參數(shù)里面的值。
采用JSON字符串// 對象的嵌套 const liyc = { name: "黎躍春", age: 100, social: { sina: "黎躍春-追時間的人", facebook: "黎躍春" } }; console.log(`liyc:${liyc}`); const dev = Object.assign({}, liyc); console.log(`dev:${dev}`); const dev2 = JSON.stringify(liyc); console.log(`dev2:${dev2}`); const dev3 = JSON.parse(JSON.stringify(liyc)); console.log(`dev3:${dev3}`);
首先調(diào)用JSON.stringify()方法將對象解析為字符串,再調(diào)用JSON.parse()方法,將字符串解析為對象,這是一個小技巧,在處理對象的復制時很有用。
Github Source Code
全棧部落 | 區(qū)塊鏈部落 |
---|---|
文章版權歸作者所有,未經(jīng)允許請勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。
轉(zhuǎn)載請注明本文地址:http://systransis.cn/yun/84616.html
摘要:派生選擇器依據(jù)元素的位置關系來定義樣式。稱其為上下文選擇器,稱其為派生選擇器。在現(xiàn)在布局中,選擇器常常用于建立派生選擇器。和一樣,也可被用作派生選擇器。 文章大綱來源:【Day 3】HTML復習 + CSS基礎 初識CSS 入門CSS 初識CSS 層疊樣式表(Cascading Style Sheets),即前端常說的CSS。 內(nèi)容引用:CSS 簡介 樣式解決了什么問題? HTML...
摘要:派生選擇器依據(jù)元素的位置關系來定義樣式。稱其為上下文選擇器,稱其為派生選擇器。在現(xiàn)在布局中,選擇器常常用于建立派生選擇器。和一樣,也可被用作派生選擇器。 文章大綱來源:【Day 3】HTML復習 + CSS基礎 初識CSS 入門CSS 初識CSS 層疊樣式表(Cascading Style Sheets),即前端常說的CSS。 內(nèi)容引用:CSS 簡介 樣式解決了什么問題? HTML...
摘要:字節(jié)碼驗證于是就寫了以下的類,用來驗證然后,然后,看字節(jié)碼如下圖。以上,就是整個關于引用傳遞和值傳遞的理解,有說的不對的,望指正。 寫這個的原因主要是今天看到了知乎的一個問題,發(fā)現(xiàn)自己有些地方有點懵逼,寫下來記錄一下,知乎上排名第一的答案說的很清楚,不過看了以后依舊有點迷迷糊糊,所以自己寫了個幾行代碼測試。首先上一個,感覺比較對的結(jié)論:**Horstmann的《java核心技術》(中文...
摘要:一創(chuàng)建實例對象依據(jù)系統(tǒng)設置的當前時間來創(chuàng)建一個對象參數(shù)代表自年月日世界標準時間起經(jīng)過的毫秒數(shù)參數(shù)表示日期的字符串值。 一、創(chuàng)建Date實例對象 1.new Date();依據(jù)系統(tǒng)設置的當前時間來創(chuàng)建一個Date對象 let today = new Date(); console.log(today); //Thu Jun 14 2018 14:51:00 GMT+080...
閱讀 1758·2021-09-22 15:25
閱讀 1318·2019-08-29 12:34
閱讀 1926·2019-08-26 13:57
閱讀 3201·2019-08-26 10:48
閱讀 1456·2019-08-26 10:45
閱讀 802·2019-08-23 18:23
閱讀 745·2019-08-23 18:01
閱讀 1957·2019-08-23 16:07