ES6知識點(diǎn)整理之對象解構(gòu)賦值應(yīng)用示例
本文實(shí)例講述了ES6知識點(diǎn)整理之對象解構(gòu)賦值應(yīng)用。分享給大家供大家參考,具體如下:
ES6 允許按照一定模式,從數(shù)組和對象中提取值,對變量進(jìn)行賦值,這被稱為解構(gòu)(Destructuring), 在對象的解構(gòu)賦值中有一些需要注意的事項(xiàng)
初識對象的解構(gòu)
var {name} = {
name:'Joh',
age:10
};
console.log(name); // Joh
通過解構(gòu)的形式取出對象中的屬性值
對解構(gòu)出的屬性進(jìn)行重命名
var {name} = {
name:'Joh',
age:10
};
console.log(name); // Joh
// 通過{屬性:新的名稱} = 對象的方式 對解構(gòu)出的屬性進(jìn)行重命名
var {color:color2} = {
color:'red',
age:10
};
console.log(color2); // red
console.log(color); // 此處報(bào)錯(cuò):Uncaught ReferenceError: color is not defined
對象嵌套解構(gòu)中模式和變量的區(qū)別
var obj = {
a:{
b:{
c:123
}
}
};
let {a:{b:{c}}} = obj; // 針對嵌套解構(gòu)的最終輸出只能是最里層的,外層的a和b都作為解構(gòu)中的一種模式存在,而不是變量,只有c能正常輸出
console.log(c); // 123
console.log(a, b, c); // Uncaught ReferenceError: a is not defined 報(bào)錯(cuò)之后停止
解析對象的默認(rèn)值
var obj = {
name:'Joh',
age:22
};
var {name, id='999', age} = obj;
console.log(name, id ,age); // Joh 999 22
var obj2 ={
name:'Lily',
age:10
};
var {name:name2, id:id2='888', age:age2} = obj2;
console.log(name2, id2, age2); // Lily 888 10
解構(gòu)對象中可能出現(xiàn)的異常
① 父解構(gòu)的節(jié)點(diǎn)為undefined,在編程中一定要注意這個(gè),屬于粗心錯(cuò)誤 :
let {x:{y}} = {name:{y:12}};
// 父結(jié)構(gòu)中沒有x屬性名, 錯(cuò)誤:Cannot destructure property `y` of 'undefined' or 'null'.
② 事先定義了一個(gè)變量重名錯(cuò)誤 :
let name;
let {name} = {name:'Joh'};
// Uncaught SyntaxError: Identifier 'name' has already been declared
解決方案1:
let name;
let {name:name2} = {name:'Joh'};
console.log(name2);
//運(yùn)行結(jié)果:Joh
解決方案2:
var name;
var {name} = {name:'Joh'};
console.log(name);
//運(yùn)行結(jié)果:Joh
感興趣的朋友可以使用在線HTML/CSS/JavaScript代碼運(yùn)行工具http://tools.jb51.net/code/HtmlJsRun測試上述代碼運(yùn)行結(jié)果。
更多關(guān)于JavaScript相關(guān)內(nèi)容可查看本站專題:《javascript面向?qū)ο笕腴T教程》、《JavaScript查找算法技巧總結(jié)》、《JavaScript錯(cuò)誤與調(diào)試技巧總結(jié)》、《JavaScript數(shù)據(jù)結(jié)構(gòu)與算法技巧總結(jié)》、《JavaScript遍歷算法與技巧總結(jié)》及《JavaScript數(shù)學(xué)運(yùn)算用法總結(jié)》
希望本文所述對大家JavaScript程序設(shè)計(jì)有所幫助。
相關(guān)文章
使用JavaScript構(gòu)建一個(gè)動態(tài)交互式圖表
在Web開發(fā)中,JavaScript不僅是實(shí)現(xiàn)交互效果的關(guān)鍵,還可以用于構(gòu)建復(fù)雜的可視化組件,如動態(tài)交互式圖表,下面我們就來看看如何構(gòu)建一個(gè)動態(tài)交互式圖表吧2024-02-02
JavaScript 模塊的循環(huán)加載實(shí)現(xiàn)方法
本文介紹JavaScript語言如何處理"循環(huán)加載"。目前,最常見的兩種模塊格式CommonJS和ES6,處理方法是不一樣的,返回的結(jié)果也不一樣2015-12-12
JS 添加網(wǎng)頁桌面快捷方式的代碼詳細(xì)整理
如何添加桌面快捷?很多網(wǎng)友都有這個(gè)疑問;JS 點(diǎn)擊添加網(wǎng)頁桌面快捷方式的代碼,需要的朋友可以參考下2012-12-12
JavaScript 一行代碼,輕松搞定浮動快捷留言-V2升級版
前天熬了大半宿發(fā)了一篇[一行代碼輕松搞定快捷留言功能],同時(shí)發(fā)布了V1.0beta版的快捷留言功能和源代碼,之所以是beta版,就是當(dāng)時(shí)感覺雖然基本功能有了,但是還不夠完善,特性也不一定合理2010-04-04
JavaScript 獲取 URL 中參數(shù)值的方法詳解(最新整理)
本文將詳細(xì)介紹幾種在 JavaScript 中獲取 URL 參數(shù)值的方法,包括現(xiàn)代瀏覽器支持的 URLSearchParams、正則表達(dá)式解析以及自定義函數(shù)解析方案,并討論各自的優(yōu)缺點(diǎn)及適用場景,感興趣的朋友一起看看吧2025-04-04
響應(yīng)式表格之固定表頭的簡單實(shí)現(xiàn)
下面小編就為大家?guī)硪黄憫?yīng)式表格之固定表頭的簡單實(shí)現(xiàn)。小編覺得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧2016-08-08
js函數(shù)獲取html中className所在的內(nèi)容并去除標(biāo)簽
本文為大家介紹下如何使用js函數(shù)獲取html中className所在的內(nèi)容,具體實(shí)現(xiàn)思路如下,喜歡的朋友可以參考下2013-09-09

