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

es6學習之解構(gòu)時應(yīng)該注意的點

 更新時間:2017年08月29日 08:58:39   作者:Funwt  
解構(gòu)賦值允許你使用類似數(shù)組或?qū)ο笞置媪康恼Z法將數(shù)組和對象的屬性賦給各種變量。這種賦值語法極度簡潔,同時還比傳統(tǒng)的屬性訪問方法更為清晰,下面這篇文章主要給大家介紹了關(guān)于在es6解構(gòu)時應(yīng)該注意的點,需要的朋友可以參考下。

前言

本文主要給大家介紹了關(guān)于在es6解構(gòu)時需要注意的一些事項,分享出來供大家參考學習,下面話不多說了,來一起看看詳細的介紹吧。

如果要將一個已經(jīng)聲明的變量用于解構(gòu)賦值,必須非常小心。

// 錯誤的寫法
let x;
{x} = {x: 1};
// SyntaxError: syntax error

上面代碼的寫法會報錯,因為 JavaScript 引擎會將{x}理解成一個代碼塊,從而發(fā)生語法錯誤。只有不將大括號寫在行首,避免 JavaScript 將其解釋為代碼塊,才能解決這個問題。

// 正確的寫法
let x;
({x} = {x: 1});

如果變量名與屬性名不一致,必須寫成下面這樣。

var { foo: baz } = { foo: 'aaa', bar: 'bbb' };
baz // "aaa"

let obj = { first: 'hello', last: 'world' };
let { first: f, last: l } = obj;
f // 'hello'
l // 'world'
//這實際上說明,對象的解構(gòu)賦值是下面形式的簡寫
let { foo: foo, bar: bar } = { foo: "aaa", bar: "bbb" };

也就是說,對象的解構(gòu)賦值的內(nèi)部機制,是先找到同名屬性,然后再賦給對應(yīng)的變量。真正被賦值的是后者,而不是前者。

let { foo: baz } = { foo: "aaa", bar: "bbb" };
baz // "aaa"
foo // error: foo is not defined
let obj = {
 p: [
 'Hello',
 { y: 'World' }
 ]
};

let { p: [x, { y }] } = obj;
x // "Hello"
y // "World"

注意:這時p是模式,不是變量,因此不會被賦值。如果p也要作為變量賦值,可以寫成下面這樣。

let obj = {
 p: [
 'Hello',
 { y: 'World' }
 ]
};

let { p, p: [x, { y }] } = obj;
x // "Hello"
y // "World"
p // ["Hello", {y: "World"}]

解構(gòu)賦值時,如果等號右邊是數(shù)值和布爾值,則會先轉(zhuǎn)為對象

let {toString: s} = 123;
s === Number.prototype.toString // true

let {toString: s} = true;
s === Boolean.prototype.toString // true

函數(shù)的參數(shù)也可以使用解構(gòu)賦值。

function add([x, y]){
 return x + y;
}

add([1, 2]); // 3

上面代碼中,函數(shù)add的參數(shù)表面上是一個數(shù)組,但在傳入?yún)?shù)的那一刻,數(shù)組參數(shù)就被解構(gòu)成變量x和y。對于函數(shù)內(nèi)部的代碼來說,它們能感受到的參數(shù)就是x和y

undefined就會觸發(fā)函數(shù)參數(shù)的默認值。

[1, undefined, 3].map((x = 'yes') => x);
// [ 1, 'yes', 3 ]

總結(jié)

以上就是這篇文章的全部內(nèi)容了,希望本文的內(nèi)容對大家的學習或者工作能帶來一定的幫助,如果有疑問大家可以留言交流,謝謝大家對腳本之家的支持。

相關(guān)文章

  • 如何基于原生javaScript生成帶圖片的二維碼

    如何基于原生javaScript生成帶圖片的二維碼

    這篇文章主要介紹了如何基于原生javaScript生成帶圖片的二維碼,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友可以參考下
    2019-11-11
  • 微信小程序分包加載的實現(xiàn)代碼

    微信小程序分包加載的實現(xiàn)代碼

    分包加載是一種小程序優(yōu)化技術(shù),將小程序不同功能的代碼,分別打包成不同的子包,在構(gòu)建時打包成不同的分包,用戶在使用時按需進行加載,在構(gòu)建小程序分包項目時,構(gòu)建會輸出一個或多個分包,這篇文章主要介紹了微信小程序---分包加載,需要的朋友可以參考下
    2024-07-07
  • java必學必會之static關(guān)鍵字

    java必學必會之static關(guān)鍵字

    java必學必會之static關(guān)鍵字,static關(guān)鍵字是很多朋友在編寫代碼和閱讀代碼時碰到的比較難以理解的一個關(guān)鍵字,下面結(jié)合大家一起學習static關(guān)鍵字
    2015-12-12
  • 淺析JavaScript 函數(shù)柯里化

    淺析JavaScript 函數(shù)柯里化

    這篇文章主要介紹了JavaScript 函數(shù)柯里化的相關(guān)資料,幫助大家更好的理解和學習JavaScript,感興趣的朋友可以了解下
    2020-09-09
  • 在JavaScript中如何訪問暫未存在的嵌套對象

    在JavaScript中如何訪問暫未存在的嵌套對象

    這篇文章主要給大家介紹了關(guān)于在JavaScript中如何訪問暫未存在的嵌套對象的相關(guān)資料,文中通過示例代碼介紹的非常詳細,對大家學習或者使用JavaScript具有一定的參考學習價值,需要的朋友們下面來一起學習學習吧
    2019-06-06
  • js實現(xiàn)HTML中Select二級聯(lián)動的實例

    js實現(xiàn)HTML中Select二級聯(lián)動的實例

    下面小編就為大家分享一篇js實現(xiàn)HTML中Select二級聯(lián)動的實例,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2018-01-01
  • js實現(xiàn)常見的工具條效果

    js實現(xiàn)常見的工具條效果

    本文主要介紹了js實現(xiàn)常見的工具條效果的實例。具有很好的參考價值,下面跟著小編一起來看下吧
    2017-03-03
  • js實現(xiàn)拖拽效果

    js實現(xiàn)拖拽效果

    本文主要是為了讓大家更好的理解js的面向?qū)ο螅ㄟ^實現(xiàn)拖拽效果向大家展示js面向?qū)ο?,非常不錯,這里推薦給大家。
    2015-02-02
  • Vue3中使用typescript封裝axios的實例詳解

    Vue3中使用typescript封裝axios的實例詳解

    這篇文章主要介紹了使用typescript封裝axios的實例代碼,為了方便,在vue3的配置里面按需加載element-plus,本文通過實例代碼給大家介紹的非常詳細,需要的朋友可以參考下
    2021-10-10
  • Webpack完整打包流程深入分析

    Webpack完整打包流程深入分析

    webpack是一種前端資源構(gòu)建工具,一個靜態(tài)模塊打包器(module bundler),下面這篇文章主要給大家介紹了關(guān)于Webpack完整打包流程的相關(guān)資料,文中通過實例代碼介紹的非常詳細,需要的朋友可以參考下
    2022-12-12

最新評論