摘要:此文章為意譯并非直譯,可參考具體原文解構(gòu)賦值具體干什么解構(gòu)賦值是中的一個(gè)表達(dá)式語(yǔ)法糖,幫助開(kāi)發(fā)者將數(shù)組,對(duì)象屬性解構(gòu)出來(lái)并且直接賦值到具體變量上面。
此文章為意譯并非直譯,可參考具體原文
解構(gòu)賦值具體干什么?解構(gòu)賦值是javascript中的一個(gè)表達(dá)式語(yǔ)法糖,幫助開(kāi)發(fā)者將數(shù)組,對(duì)象屬性解構(gòu)出來(lái)并且直接賦值到具體變量上面。
let a,b,rest; [a,b] = [10,20]; console.log(a);// 10, console.log(b);// 20; [a,b,...rest] = [10,20,30,40,50,60]; console.log(a); // 10 console.log(b); // 20 console.log(rest);// [30,40,50,60]
let a=10,b=20; [a,b]=[b,a]; console.log(a);// 20 console.log(b);// 10;解構(gòu)賦值具體使用方式
// 1. 從已有對(duì)數(shù)組中解構(gòu)賦值 let foo = ["one","two","three"]; let [a,b] = foo; console.log(a); console.log(b); // 2. 從字面量中解構(gòu)賦值 let [a,b] = [1,2]; // 3. 在解構(gòu)賦值對(duì)時(shí)候設(shè)置默認(rèn)值 let [a=5, b=10] = [1]; console.log(a); // 輸出:1 console.log(b); // 輸出:10 // 4. 解構(gòu)從函數(shù)返回對(duì)數(shù)組 function getArr(){ return [1,2] } let [a,b] = getArr(); // 5. 解構(gòu)對(duì)時(shí)候,忽略特殊位置對(duì)值 let [a,,b] = [1,2,3]; // 全部忽略 [,,] = [1,2,3]; // 6. 解構(gòu)對(duì)時(shí)候?qū)?shù)組的其他值賦值給變量 let [a,...b] = [1,2,3,4,5]; console.log(a);// 1 console.log(b);// [2,3,4,5]
// 1. 解構(gòu)對(duì)象 let obj = {name:"hello",age:18}; let {name,age} = obj; console.log(name);// hello; console.log(age);// 18 // 2. 解構(gòu)字面量對(duì)象 let name,age; ({name,age} = {name:"hello",age:18});// 結(jié)果和上面一樣,注意,這里為什么需要用`()`包裹起來(lái)呢? // 獨(dú)立的寫(xiě)法 let {name,age} = {name:"hello",age:18}; // 3. 解構(gòu)的時(shí)候,設(shè)置別名 let obj = {name:"hello",age:18}; let {name:nameA,age:ageA} = obj; console.log(nameA);// hello console.log(ageA);// 18 // 4. 設(shè)置默認(rèn)值,這個(gè)和數(shù)組解構(gòu)類似 let obj = {name:"hello",age:18}; let {name="tom",age=20,city="sh"}=obj; console.log(city);// sh // 5. 設(shè)置默認(rèn)值,同時(shí)又設(shè)置別名 let obj = {n:"hello",age:18}; let {n:name="tom",age:a=19,city:c="sh"} = obj; console.log(name); // hello console.log(a); // 18 console.log(c); // sh // 6. 設(shè)置函數(shù)參數(shù)的默認(rèn)值 function drawES2015Chart({size = "big", cords = {x: 0, y: 0}, radius = 25} = {}) { console.log(size, cords, radius); // do some chart drawing } drawES2015Chart({ cords: {x: 18, y: 30}, radius: 30 });
let data = { title:"objetAdnArray", list:[ { id:1, des:"第一個(gè)對(duì)象", proList:[] }, { id:2, des:"第二個(gè)對(duì)象", proList: [] } ] } let { title, list:[{id,des}] } = data; console.log(title); // objetAdnArray console.log(id); // 1 console.log(des); // 第一個(gè)對(duì)象
var people = [ { name: "Mike Smith", family: { mother: "Jane Smith", father: "Harry Smith", sister: "Samantha Smith" }, age: 35 }, { name: "Tom Jones", family: { mother: "Norah Jones", father: "Richard Jones", brother: "Howard Jones" }, age: 25 } ]; for (let {name: n, family: {father: f}} of people) { console.log("Name: " + n + ", Father: " + f); } // "Name: Mike Smith, Father: Harry Smith" // "Name: Tom Jones, Father: Richard Jones"
function userId({id}) { return id; } function whois({displayName, fullName: {firstName: name}}) { console.log(displayName + " is " + name); } var user = { id: 42, displayName: "jdoe", fullName: { firstName: "John", lastName: "Doe" } }; console.log("userId: " + userId(user)); // "userId: 42" whois(user); // "jdoe is John"
let key = "z"; let {[key]:foo} = {z:"this is z"}; console.log(foo); // this is z // 注意,這個(gè)用戶很類似對(duì)象字面量賦值的用法 let obj = { [key]:"hello" } obj.z // hello
總結(jié):es6提供了許多語(yǔ)法糖,在客戶端使用的時(shí)候需要通過(guò)進(jìn)行編譯才能運(yùn)行,而在服務(wù)器端nodejs已經(jīng)很好的支持了
文章版權(quán)歸作者所有,未經(jīng)允許請(qǐng)勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。
轉(zhuǎn)載請(qǐng)注明本文地址:http://systransis.cn/yun/92685.html
摘要:是這樣描述解構(gòu)賦值的解構(gòu)賦值語(yǔ)法是一種表達(dá)式用來(lái)將數(shù)組中的值或?qū)ο笾械膶傩匀〕鰜?lái)區(qū)分為不同變量?,F(xiàn)在讓我們將坐標(biāo)點(diǎn)放進(jìn)一個(gè)數(shù)組中現(xiàn)在要對(duì)這些點(diǎn)進(jìn)行處理,傳統(tǒng)可以想到的方法是這樣的借助解構(gòu)賦值,能變得這樣簡(jiǎn)潔使用箭頭函數(shù)更簡(jiǎn)潔 JavaScript是一種很有趣的語(yǔ)言,我個(gè)人很喜歡它,雖然仍還有些人不大喜歡它。在ECMAScript6(ES6)中,有許多有用的特性來(lái)使JavaScript開(kāi)...
摘要:相信解構(gòu)賦值自以下簡(jiǎn)稱面世以來(lái)被大家快速地熟悉并運(yùn)用到實(shí)際開(kāi)發(fā)中了這是一種能有效減少代碼量,使代碼邏輯更簡(jiǎn)單優(yōu)雅的技術(shù)下面我們就再來(lái)回顧總結(jié)一下解構(gòu)賦值的種種用法吧基本用法從對(duì)象解構(gòu)假設(shè)有一個(gè)對(duì)象,它的結(jié)構(gòu)為以對(duì)稱的形式從從邊的對(duì)象中匹配與 相信解構(gòu)賦值(Destructuring)自 ECMASCRIPT 6(以下簡(jiǎn)稱 ES 6) 面世以來(lái)被大家快速地熟悉并運(yùn)用到實(shí)際開(kāi)發(fā)中了, 這是...
摘要:解構(gòu)賦值允許我們將右邊的表達(dá)式看起來(lái)也像變量聲明一般,然后在左邊將值一一提取。數(shù)組的解構(gòu)賦值現(xiàn)在假設(shè)我們有一個(gè)變量,其值為。通過(guò),這會(huì)看上去更清晰簡(jiǎn)潔最后的解構(gòu)賦值給的語(yǔ)法帶來(lái)了更多的現(xiàn)代化。 前言 讓我們來(lái)仔細(xì)地看看ES6所帶來(lái)的更清晰的變量聲明與賦值語(yǔ)法?,F(xiàn)今的變量聲明語(yǔ)法十分的直接:左邊是一個(gè)變量名,右邊可以是一個(gè)數(shù)組:[]的表達(dá)式或一個(gè)對(duì)象:{}的表達(dá)式,等等。解構(gòu)賦值允許我...
摘要:它是一個(gè)通用標(biāo)準(zhǔn),奠定了的基本語(yǔ)法。年月發(fā)布了的第一個(gè)版本,正式名稱就是標(biāo)準(zhǔn)簡(jiǎn)稱。結(jié)語(yǔ)的基本擴(kuò)展還有一些沒(méi)有在這里詳細(xì)介紹。 前言 ES6標(biāo)準(zhǔn)以及頒布兩年了,但是,好像還沒(méi)有完全走進(jìn)我們的日常開(kāi)發(fā)。這篇文章從ES6的基本類型擴(kuò)展入手,逐步展開(kāi)對(duì)ES6的介紹。 ECMAScript和JavaScript JavaScript是由Netscape創(chuàng)造的,該公司1996年11月將JavaSc...
摘要:具體的分析暫時(shí)不討論解決的方式很簡(jiǎn)單,把上面的代碼塊變成一段表達(dá)式就小明總結(jié)解構(gòu)賦值是提供一個(gè)十分方便的表達(dá)式。的解構(gòu)賦值小明的對(duì)象賦值這里可以被賦予初始值小明對(duì)象的屬性不存在能夠賦值給多個(gè)變量 對(duì)象解構(gòu)賦值 ES6 允許按照一定模式,從數(shù)組和對(duì)象中提取值,對(duì)變量進(jìn)行賦值,這被稱為解構(gòu)(Destructuring)。 --- 阮一峰《ECMAScript...
閱讀 2615·2021-11-02 14:39
閱讀 4342·2021-10-11 10:58
閱讀 1468·2021-09-06 15:12
閱讀 1853·2021-09-01 10:49
閱讀 1339·2019-08-29 18:31
閱讀 1890·2019-08-29 16:10
閱讀 3348·2019-08-28 18:21
閱讀 879·2019-08-26 10:42