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

ES6新語法之解構(gòu)實(shí)踐指南

 更新時(shí)間:2022年06月16日 10:53:57   作者:言不及行yyds  
所謂解構(gòu)就是解構(gòu)聚合數(shù)據(jù),下面這篇文章主要給大家介紹了關(guān)于ES6新語法之解構(gòu)的相關(guān)資料,文中通過實(shí)例代碼介紹的非常詳細(xì),需要的朋友可以參考下

1.解構(gòu)初了解

解構(gòu)是ES6的一個(gè)新的語法特性,可以把他看作是一個(gè)

具有結(jié)構(gòu)賦值功能的一個(gè)語法。

關(guān)于解構(gòu)通常有倆種,有數(shù)組解構(gòu)和對(duì)象解構(gòu)

解構(gòu)有什么優(yōu)點(diǎn)嗎?為什么我們用他。

ok,讓我們用一個(gè)例子來顯示一下解構(gòu)的優(yōu)點(diǎn)

定義一個(gè)函數(shù),返回一個(gè)數(shù)組(含3個(gè)數(shù)),用a,b,c來接受。

1.用平常的語法

function foo(){
            return [1,2,3]
        }
var temp=foo(),
a=temp[0],b=temp[1],c=temp[2]
console.log(a,b,c)

構(gòu)造一個(gè)函數(shù)手動(dòng)賦值,用一個(gè)臨時(shí)變量temp,將值傳遞給a,b,c

2.用解構(gòu)的方法

  function foo(){
      return [1,2,3]
      }
   var [a,b,c]=foo()
  console.log(a,b,c)

在輸出的結(jié)果都是一樣,都輸出(1,2,3)

所以你怎么選。

2.解構(gòu)詳細(xì)解析

2.1對(duì)象屬性賦值形式

相比于之前的賦值形式我們都熟悉與=a的賦值形式

但是解構(gòu)語法翻轉(zhuǎn)了這種形式,,左側(cè)變量作為一個(gè)“模式”

用于將右側(cè)的數(shù)組賦值給左側(cè)的變量

接著討論一下在上面{a,b,c}其實(shí)是{a:a,b:b,c:c}的簡(jiǎn)寫。

那么在賦值的時(shí)候省略的部分是a:   還是 :a

在這我們就需要去了解對(duì)象屬性賦值形式

function foo(){
      return {a:4,b:5,c:6}
    }
var { a:aitem,b:bitem,c:citem }=foo()
     
 console.log(aitem,bitem,citem)
 
 var x=10,y=20
 var o={d:x,e:y}
 console.log(o.d,o.e)

 現(xiàn)在我們大概能明白了吧,

用一張圖來解釋

a27775d61b604a1a92f718a3bc62eafe.png

2.2變量的聲明

在前面我們看到了使用var聲明變量,其實(shí)也可以使用let,const聲明

也可以通過IEIF的形式賦值比如({x,y,z}=bar())

 好的,那么關(guān)于變量的話,他只能被設(shè)置為變量標(biāo)識(shí)符嗎?

這種想法是愚蠢的,任何合法的賦值表達(dá)式都可以

用兩個(gè)例子來解析

2.3怎么解構(gòu)

記住一個(gè)原則,對(duì)稱解構(gòu)。

1.解構(gòu)的過多

 怎么理解,就是左右的賦值不對(duì)稱,并不是所有的值都用來解構(gòu),

多余的值會(huì)被設(shè)置為undefinder

2解構(gòu)的過少

右側(cè)的"變量"多余左側(cè)的變量

3.解構(gòu)正好

左右變量相等

 數(shù)組的解構(gòu)是按順序排列的,變量的取值有他的位置決定

對(duì)象的解構(gòu),對(duì)象的屬性沒有次序,變量必須與屬性同名,才能取到正確的值,對(duì)象的解構(gòu)賦值的內(nèi)部機(jī)制,是先找到同名屬性,然后再賦給對(duì)應(yīng)的變量。真正被賦值的是后者,而不是前者

3.實(shí)踐

3.1數(shù)組的解構(gòu)

var a1=[1,[2,3,[4]],5]
var [a,[b,c,[d]],e]=a1
console.log(a,b,c,d,e)

輸出1,2,3,4,5

在這里采用重復(fù)解構(gòu)的形式,解構(gòu)的形式就是從內(nèi)向外依次解構(gòu)

3.2對(duì)象的解構(gòu)

var  o1={a:{b:{c:6}}}
var {a:{b:{c:w}}}=o1
console.log(w)

輸出6

3.3解構(gòu)參數(shù)

 function foo({x,y}){
        console.log(x.y)
    }
console.log(3,4)

輸出3,4,如果是console.log(3)的話會(huì)報(bào)錯(cuò),但是x的值是已經(jīng)解構(gòu)的

3.4復(fù)雜解構(gòu)

let wangfei = {
name: "王菲",
   age: 18,
  songs: ["紅豆", "流年", "曖昧", "傳奇"],
  history: [{ name: "竇唯" }, { name: "李亞鵬" }, { name: "謝霆鋒" }],
};
 
let {
   songs: [one, two, three],
  history: [first, second, third],
} = wangfei;
console.log(one, two, three,first, second, third)

44485beae5484ba78a5e2b0028e70e36.png

 4.總結(jié)

1.了解了解構(gòu)的含義,及優(yōu)點(diǎn)

2.學(xué)會(huì)了解構(gòu)對(duì)象屬性賦值的形式

3.了解了一些解構(gòu)的技巧

4.用幾個(gè)例子來動(dòng)手實(shí)踐。

到此這篇關(guān)于ES6新語法之解構(gòu)的文章就介紹到這了,更多相關(guān)ES6新語法解構(gòu)內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • JS實(shí)現(xiàn)深拷貝的幾種簡(jiǎn)單方法示例

    JS實(shí)現(xiàn)深拷貝的幾種簡(jiǎn)單方法示例

    深拷貝和淺拷貝是在JavaScript中復(fù)制對(duì)象或數(shù)組時(shí)經(jīng)常遇到的概念,下面這篇文章主要給大家介紹了關(guān)于JS實(shí)現(xiàn)深拷貝的幾種簡(jiǎn)單方法,文中通過代碼介紹的非常詳細(xì),需要的朋友可以參考下
    2023-10-10
  • javascript設(shè)計(jì)模式之module(模塊)模式

    javascript設(shè)計(jì)模式之module(模塊)模式

    這篇文章主要為大家詳細(xì)介紹了javascript設(shè)計(jì)模式之module(模塊)模式 ,感興趣的小伙伴們可以參考一下
    2016-08-08
  • 談一談javascript閉包

    談一談javascript閉包

    這篇文章主要介紹了javascript閉包,閉包(closure)是Javascript語言的一個(gè)難點(diǎn),也是它的特色,很多高級(jí)應(yīng)用都要依靠閉包實(shí)現(xiàn),感興趣的小伙伴們可以參考一下
    2016-01-01
  • JavaScript html5 canvas繪制時(shí)鐘效果

    JavaScript html5 canvas繪制時(shí)鐘效果

    這篇文章主要介紹了JavaScript html5繪制時(shí)鐘效果的相關(guān)資料,使用HTML5的canvas標(biāo)簽和Javascript腳本,模擬顯示了一個(gè)時(shí)鐘,感興趣的小伙伴們可以參考一下
    2016-03-03
  • 序列化模塊json代碼實(shí)例詳解

    序列化模塊json代碼實(shí)例詳解

    這篇文章主要介紹了序列化模塊json代碼實(shí)例詳解,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下
    2020-03-03
  • 圖解JavaScript中的this關(guān)鍵字

    圖解JavaScript中的this關(guān)鍵字

    這篇文章利用圖片講解的方式向大家解釋了JavaScript中的this關(guān)鍵字,JavaScript this 到底指向什么?從這篇文章中大家可以得到想要的答案,需要的朋友可以參考下
    2015-10-10
  • js實(shí)現(xiàn)省市級(jí)聯(lián)效果分享

    js實(shí)現(xiàn)省市級(jí)聯(lián)效果分享

    這篇文章主要為大家詳細(xì)介紹了js實(shí)現(xiàn)省市級(jí)聯(lián)效果,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2017-08-08
  • 基于JavaScript實(shí)現(xiàn)瀑布流效果

    基于JavaScript實(shí)現(xiàn)瀑布流效果

    這篇文章主要為大家詳細(xì)介紹了基于JavaScript實(shí)現(xiàn)瀑布流效果,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2017-03-03
  • js基礎(chǔ)之DOM中document對(duì)象的常用屬性方法詳解

    js基礎(chǔ)之DOM中document對(duì)象的常用屬性方法詳解

    下面小編就為大家?guī)硪黄猨s基礎(chǔ)之DOM中document對(duì)象的常用屬性方法詳解。小編覺得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧
    2016-10-10
  • javascript 構(gòu)造函數(shù)強(qiáng)制調(diào)用經(jīng)驗(yàn)總結(jié)

    javascript 構(gòu)造函數(shù)強(qiáng)制調(diào)用經(jīng)驗(yàn)總結(jié)

    本文將介紹javascript構(gòu)造函數(shù)調(diào)用方面的案例應(yīng)用,需要了解的朋友可以參考下
    2012-12-12

最新評(píng)論