欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

ES6基礎(chǔ)之解構(gòu)賦值(destructuring assignment)

 更新時間:2019年02月21日 10:47:06   作者:前端達人  
這篇文章主要介紹了ES6基礎(chǔ)之解構(gòu)賦值(destructuring assignment),小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧

我們經(jīng)??梢栽谄渌幊陶Z言(如GO語言)中看到多返回值這種特性,因為在很多實際場景中,函數(shù)的返回值中,函數(shù)的返回值并不只有一個單一的值。ES6之前,并沒有可以直接使用語法來實現(xiàn)多返回值的特性。ES6終于出現(xiàn)了解構(gòu)賦值的語法糖來解決此類問題。

解構(gòu)賦值是一種表達式,允許您使用數(shù)組或?qū)ο螅瑢⒖傻鷮ο蟮闹祷驅(qū)傩苑峙浣o變量。解構(gòu)賦值能讓我們用更簡短的語法進行多個變量的賦值,大大的減少了代碼量。解構(gòu)表達式有兩種:array和object。

今天的文章筆者將從以下方面進行介紹:

  • 使用數(shù)組表達式解構(gòu)賦值
    • 常規(guī)用法
    • 忽略數(shù)組中的某些值
    • 使用展開語法
    • 默認參數(shù)值
    • 嵌套數(shù)組解構(gòu)
    • 作為函數(shù)參數(shù)
  • 使用對象表達式解構(gòu)賦值
    • 常規(guī)用法
    • 默認參數(shù)值
    • 嵌套對象
    • 作為函數(shù)參數(shù)
  • 其他
    • 解構(gòu)對象的方法
    • 獲取字符串長度
    • 拆分字符串
    • 交換變量
    • 遍歷Map結(jié)構(gòu)
    • 加載指定模塊的方法
  • 常用場景介紹

使用數(shù)組表達式解構(gòu)賦值

常規(guī)用法

如何將一個數(shù)組的值,賦值給多個變量?數(shù)組解構(gòu)語法能讓我們快速的迭代數(shù)組的元素,并賦值給多個變量。

E6之前,我們可以這種形式將數(shù)組的內(nèi)容賦值給多個變量:

var myArray = [1, 2, 3];
var a = myArray[0];
var b = myArray[1];
var c = myArray[2];

ES6后,我們可以通過數(shù)組解構(gòu)語法,在一行語句里完成上述操作。

let myArray = [1, 2, 3];
let a, b, c;
[a, b, c] = myArray; //array destructuring assignment syntax

上述代碼中,[a, b, c]就是解構(gòu)表達式。在數(shù)組解構(gòu)語句的左側(cè)就是需要進行賦值的多個變量,等號右側(cè)則是我們需要分配的值。

我們還可以讓上述代碼更短,你還可以這么寫,代碼如下:

let [a, b, c] = [1, 2, 3];

我們在同一行語句中創(chuàng)建變量,而不是分別創(chuàng)建。是不是更清爽。

如果左邊的數(shù)值少于右邊數(shù)組的項數(shù),左邊變量的值只會和右邊數(shù)組的內(nèi)容一一對應(yīng),多于的內(nèi)容將會忽略。

忽略數(shù)組中某些值

如果只有兩個變量,我們數(shù)組內(nèi)容有三項,我們想跳過數(shù)組中的第二項,我們?nèi)绾问褂脭?shù)組解構(gòu)賦值呢?代碼如下:

let [a, , b] = [1, 2, 3];
console.log(a);
console.log(b);

上述代碼我們使用, ,忽略數(shù)組中的第二項,建議中間有空格,方便我們閱讀。

使用展開語法

上篇文章 《【ES6基礎(chǔ)】展開語法(Spread syntax)》 ,筆者介紹了展開語法的幾個應(yīng)用場景,由于上篇文章沒介紹解構(gòu)賦值,所以在這里給大家介紹展開語法在解構(gòu)賦值的應(yīng)用。如下段代碼所示:

let [a, ...b] = [1, 2, 3, 4, 5, 6];
console.log(a);
console.log(Array.isArray(b));
console.log(b);”

上述代碼則會輸出:

1
true
2,3,4,5,6

上述代碼,你可以看到b變量被解構(gòu)賦值成數(shù)組,這里...就是我們上篇文章提到的剩余參數(shù)場景的運用。

如果想跳過數(shù)組中的部分值,我們可以這么做,如下段代碼所示:

let [a, , ,...b] = [1, 2, 3, 4, 5, 6];
console.log(a);
console.log(b);

上述代碼則會輸出:

1
4,5,6

這段代碼我們跳過了數(shù)組的第2項和第3項。

默認參數(shù)值

筆者在 《【ES6基礎(chǔ)】默認參數(shù)值》 給大家介紹了如何使用默認參數(shù)值,在解構(gòu)賦值中,我們?nèi)绾卧O(shè)置變量的默認值呢,如下段代碼所示:

let [a, b, c = 3] = [1, 2];
console.log(c); //Output "3”

嵌套數(shù)組

我們還可以從多維數(shù)組中提取值并分配給變量,如下段代碼所示:

let [a, b, [c, d]] = [1, 2, [3, 4]];

作為函數(shù)參數(shù)

我們還可以使用數(shù)組解構(gòu)表達式作為函數(shù)參數(shù)來提取可迭代數(shù)組的值,作為參數(shù)傳遞給函數(shù)參數(shù),如下段代碼所示:

function myFunction([a, b, c = 3]) {
   console.log(a, b, c); //Output "1 2 3"
  }
myFunction([1, 2]);

筆者在《【ES6基礎(chǔ)】默認參數(shù)值》 提及到我們可以傳遞undefined,指定某個具體的參數(shù)使用默認值,我們可以使用結(jié)構(gòu)賦值為相關(guān)變量提供一組默認值,并傳入undefined,如下段代碼所示:

function myFunction([a, b, c = 3] = [1, 2, 3]) {
   console.log(a, b, c); //Output "1 2 3"
  }
myFunction(undefined);

在這里,我們將undefined作為參數(shù)傳遞,因此使用默認數(shù)組[1,2,3]進行提取賦值。

使用對象表達式解構(gòu)賦值

常規(guī)用法

對象解構(gòu)賦值將對象屬性的值賦給多個變量。ES6之前我們可以這樣把對象的屬性賦值給多個變量,如下段代碼所示:

var object = {name : "John", age : 23};
var name = object.name;
var age = object.age;

在ES6里,我們可以使用對象解構(gòu)表達式,在單行里給多個變量賦值,如下段代碼所示:

let object = {name : "John", age : 23};
let name, age;
({name, age} = object); //object destructuring assignment syntax

對象解構(gòu)賦值的左側(cè)為解構(gòu)賦值表達式,右側(cè)為對應(yīng)要分配賦值的對象。解構(gòu)語句的兩邊千萬 不要遺漏左右括號() ,否則會報錯。

還有一點需要格外注意,解構(gòu)對象 變量的名稱一定要和右邊對象的屬性名稱保持一致 ,否則會提示變量的值為undefined。如果你想以其它的變量名進行命名,你可以這么做,如下段代碼所示:

let object = {name : "John", age : 23};
let x, y;
({name: x, age: y} = object);

上述代碼x,y為對應(yīng)對象屬性的值John,23。如果你輸出name或age,編譯器則會提示ReferenceError: 變量 is not defined

我們可以讓代碼更短,如下段代碼所示:

let {name: x, age: y} = {name : "John", age : 23};

上述代碼由于聲明變量和解構(gòu)賦值在同一行,因此對象解構(gòu)語句兩邊無需左右括號()。

默認參數(shù)值

在解構(gòu)對象針對未分配值的變量,我們可以為變量提供默認值,如下段代碼所示:

let {a, b, c = 3} = {a: "1", b: "2"};
console.log(c); //Output "3”

在解構(gòu)對象時變量名支持表達式計算,如下段代碼所示:

let {["first"+"Name"]: x} = { firstName: "Eden" };
console.log(x); //Output "Eden”

嵌套對象

我們還可以從嵌套對象中提取屬性值,即對象中的對象。 如下段代碼所示:

let {name, otherInfo: {age}} = {name: "Eden", otherInfo: {age:23}};
console.log(name, age); //Eden 23

作為函數(shù)參數(shù)

就像數(shù)組解構(gòu)賦值一樣,我們也可以使用對象解構(gòu)賦值作為函數(shù)參數(shù),如下段代碼所示:

function myFunction({name = 'Eden', age = 23, profession ="Designer"} = {}){
  console.log(name, age, profession); // Outputs "John 23 Designer"
}
myFunction({name: "John", age: 23});

在這里,我們傳遞一個空對象作為默認參數(shù)值,如果將undefined作為函數(shù)參數(shù)傳遞,變量將使用默認值。

其他

解構(gòu)對象的方法

比如結(jié)構(gòu)Math對象的方法,如下段代碼所示:

let {floor,pow}=Math;//把Math里的方法提取出來變成一個變量
let a=1.1;
console.log(floor(a));//1
console.log(pow(2,3));//8

獲取字符串的長度

var {length}='lxy';
console.log(length);//3

拆分字符串

var [a,b,c,d]='前端達人';
console.log(a,b,c,d) // 輸出:前 端 達 人

交換變量

let x = 1;
let y = 2;
[x, y] = [y, x];

遍歷Map結(jié)構(gòu)

var map = new Map();
map.set('first', 'hello');
map.set('second', 'world');

for (let [key, value] of map) {
  console.log(key + " is " + value);
}

加載指定模塊的方法

const { SourceMapConsumer, SourceNode } = require("source-map");

常用場景介紹

比如我們經(jīng)常與后端API接口做數(shù)據(jù)交互,我們需要處理返回的JSON對象,使用解構(gòu)方式大大簡化了我們的代碼,如下段代碼所示:

let jsonData = {
  id: 42,
  status: "OK",
  data: [867, 5309]
};
let { id, status, data: number } = jsonData;
console.log(id, status, number);
// 42, "OK", [867, 5309]

小節(jié)

今天的內(nèi)容有些多,想必大家對解構(gòu)賦值有了全面的認識吧,使用解構(gòu)賦值是不是很強大,大大簡化了我們的代碼量,雖然優(yōu)勢蠻多,但是增加對代碼的理解難度,我們只有在實踐中不斷的運用,來加深我們對解構(gòu)賦值的認識。

以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。

相關(guān)文章

  • JavaScript switch case 的用法實例[范圍]

    JavaScript switch case 的用法實例[范圍]

    JavaScript switch case 的用法實例,大家可以參考下。
    2009-09-09
  • 一個高效的JavaScript壓縮工具下載集合

    一個高效的JavaScript壓縮工具下載集合

    這里介紹的是一些比較常用的js 壓縮工具,隨著問題的不斷解決,好用的工具要經(jīng)得起考驗。
    2007-03-03
  • xml和web特殊字符

    xml和web特殊字符

    在html和xml文件中,往往會因為以下特殊字符而導(dǎo)致文件解析出錯,一般通過以下函數(shù)來處理。
    2009-04-04
  • js前端上傳文件縮略圖技巧示例詳解

    js前端上傳文件縮略圖技巧示例詳解

    這篇文章主要為大家介紹了js前端上傳文件縮略圖技巧示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2023-03-03
  • JS循環(huán)發(fā)送請求時控制請求并發(fā)數(shù)實例

    JS循環(huán)發(fā)送請求時控制請求并發(fā)數(shù)實例

    這篇文章主要介紹了JS循環(huán)發(fā)送請求時控制請求并發(fā)數(shù)實例,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2023-12-12
  • 微信小程序反編譯的實現(xiàn)

    微信小程序反編譯的實現(xiàn)

    這篇文章主要介紹了微信小程序反編譯的實現(xiàn),文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2020-12-12
  • JavaScript圣杯布局與雙飛翼布局實現(xiàn)案例詳解

    JavaScript圣杯布局與雙飛翼布局實現(xiàn)案例詳解

    這篇文章主要介紹了JavaScript圣杯布局與雙飛翼布局實現(xiàn)案例,這是前端面試中需要掌握的知識點,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2022-08-08
  • JavaScript 事件對象的實現(xiàn)

    JavaScript 事件對象的實現(xiàn)

    前我寫過一篇關(guān)于JavaScript如何實現(xiàn)面向?qū)ο缶幊痰奈恼?。今天,我寫這篇文章跟大家討論一下,如何實現(xiàn)事件。
    2009-07-07
  • 微信小程序列表中item左滑刪除功能

    微信小程序列表中item左滑刪除功能

    這篇文章主要介紹了微信小程序列表中item左滑刪除功能,本文分步驟給大家介紹的非常詳細,具有一定的參考借鑒價值,需要的朋友可以參考下
    2018-11-11
  • JS簡單封裝的圖片無縫滾動效果示例【測試可用】

    JS簡單封裝的圖片無縫滾動效果示例【測試可用】

    這篇文章主要介紹了JS簡單封裝的圖片無縫滾動效果,結(jié)合完整實例形式分析了javascript針對圖片無縫滾動功能實現(xiàn)的具體操作技巧,包括鼠標(biāo)事件響應(yīng)、事件函數(shù)及頁面元素屬性動態(tài)變換等相關(guān)操作技巧,需要的朋友可以參考下
    2017-03-03

最新評論