清空和截短數(shù)組
最簡(jiǎn)單的清空和截短數(shù)組的方法就是改變 length 屬性:
data:image/s3,"s3://crabby-images/336f7/336f794989fd71312a8b74a2b075818b668c033b" alt="1553764080158_1.png"
使用對(duì)象結(jié)構(gòu)模擬命名參數(shù)
以前,當(dāng)我們希望向一個(gè)函數(shù)傳遞多個(gè)參數(shù)時(shí),可能會(huì)采用配置對(duì)象的模式:
data:image/s3,"s3://crabby-images/ca4ac/ca4ac740cdffd5a32668008b57d6d7e0aaccf7a7" alt="1553764085269_2.png"
這是一個(gè)古老但是有效的模式,有了 ES2015 的對(duì)象結(jié)構(gòu),你可以這樣使用:
data:image/s3,"s3://crabby-images/37eb0/37eb01ccfbd54e8f7c85f2db589b54d3b6c3d4aa" alt="1553764090181_3.png"
如果你需要這個(gè)配置對(duì)象參數(shù)變成可選的,也很簡(jiǎn)單:
data:image/s3,"s3://crabby-images/995cf/995cfd4f2d1494c568529c2677f6846d819e8bc3" alt="1553764094504_4.png"
數(shù)組的對(duì)象解構(gòu)
使用對(duì)象解構(gòu)將數(shù)組項(xiàng)賦值給變量:
data:image/s3,"s3://crabby-images/f992f/f992ffe0b848365aaf9f081bc249f5f35071e887" alt="1553764099107_5.png"
注:本例中,2 為 split 之后的數(shù)組下標(biāo),country 為指定的變量,值為 US
switch 語(yǔ)句中使用范圍
這是一個(gè)在 switch 語(yǔ)句中使用范圍的例子:
data:image/s3,"s3://crabby-images/5671c/5671caa76d1a77e12435f12c8f3a6df47a0c998b" alt="1553764107908_6.png"
await 多個(gè) async 函數(shù)
await 多個(gè) async 函數(shù)并等待他們執(zhí)行完成,我們可以使用 Promise.all:
data:image/s3,"s3://crabby-images/9bd5d/9bd5d483a0463b58c8972d40f1569c14672c505c" alt="1553764113163_7.png"
創(chuàng)建純對(duì)象
你可以創(chuàng)建一個(gè) 100% 的純對(duì)象,這個(gè)對(duì)象不會(huì)繼承 Object 的任何屬性和方法(比如 constructor,toString() 等):
data:image/s3,"s3://crabby-images/112e5/112e508d2db8e802ded7c0882d8d86e461f1ce57" alt="1553764120997_8.png"
格式化 JSON 代碼
JSON.stringify 不僅可以字符串化對(duì)象,它也可以格式化你的 JSON 輸出:
移除數(shù)組重復(fù)項(xiàng)
使用 ES2015 和擴(kuò)展運(yùn)算符,你可以輕松移除數(shù)組中的重復(fù)項(xiàng):
data:image/s3,"s3://crabby-images/19d85/19d854600f9a2e3baa71ef68a6fd214a8096111c" alt="1553764130410_10.png"
注:只適用于數(shù)組內(nèi)容為基本數(shù)據(jù)類型
扁平化多維數(shù)組
使用擴(kuò)展運(yùn)算符可以快速扁平化數(shù)組:
data:image/s3,"s3://crabby-images/82954/82954078d2d16dd40bbc510768d72fa0c0823d7e" alt="1553764135402_11.png"
不幸的是,上面的技巧只能適用二維數(shù)組,但是使用遞歸,我們可以扁平化任意緯度數(shù)組:
data:image/s3,"s3://crabby-images/d84c1/d84c19cc580996eddea8fbd16578a3da2473fa0e" alt="1553764140361_12.png"
作者:黑馬程序員前端與移動(dòng)開(kāi)發(fā)培訓(xùn)學(xué)院
首發(fā):http://web.itheima.com/