亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

JavaScript對(duì)象解構(gòu)的用法實(shí)例解析

 更新時(shí)間:2022年01月23日 17:05:21   作者:半夏的故事  
解構(gòu)賦值允許你使用類似數(shù)組或?qū)ο笞置媪康恼Z(yǔ)法將數(shù)組和對(duì)象的屬性賦給各種變量,下面這篇文章主要給大家介紹了關(guān)于JavaScript對(duì)象解構(gòu)用法的相關(guān)資料,文中通過(guò)實(shí)例代碼介紹的非常詳細(xì),需要的朋友可以參考下

前言

ES6(ES2015)的發(fā)布,給JavaScript 提供了一種更方便快捷的方式來(lái)處理對(duì)象的屬性。該機(jī)制稱為Destructuring(也稱為解構(gòu)賦值)。但是你真的會(huì)用嗎?你真的了解各種場(chǎng)景下,解構(gòu)賦值的用法嗎?

使用解構(gòu)從對(duì)象中獲取值

對(duì)象解構(gòu)最基本的用法是從對(duì)象中檢索屬性鍵的值。

例如,我們定義了一個(gè)對(duì)象,他有兩個(gè)屬性:name和age

const User = {
  name: '搞前端的半夏',
  age: 18
}

傳統(tǒng)上,我們將使用點(diǎn) (.) 表示法或下標(biāo) ([]) 表示法從對(duì)象中檢索值。下面的代碼片段顯示了使用點(diǎn)符號(hào)檢索對(duì)象的值id和name從對(duì)象中檢索值的示例。employee

在之前我們想要獲取對(duì)象中某個(gè)屬性的值,通產(chǎn)是使用.或者[]。

const name = User['name'];
const age = User.age;

當(dāng)然這兩種方式在當(dāng)前情況下是沒有問題的,但是當(dāng)User的屬性多了,我們就要不停的復(fù)制粘貼,產(chǎn)生很多重復(fù)的代碼。

有了結(jié)構(gòu)賦值,我們就可以快速的來(lái)獲取值。例如我們使用對(duì)象的鍵名來(lái)創(chuàng)建變量,并將對(duì)象的值分配給相同的鍵。這樣無(wú)論有多少屬性,我們只要賦值屬性名即可,同樣的也減少了很多重復(fù)代碼。

const { name, age } = User;

使用解構(gòu)從嵌套對(duì)象中獲取值

在上面的例子中,User只是一個(gè)簡(jiǎn)單的單層對(duì)象,我們?cè)谌粘5拈_發(fā)中也會(huì)遇到嵌套的對(duì)象,,那么使用結(jié)構(gòu)賦值,我們?cè)撊绾螜z索嵌套對(duì)象中的值。下面我們重新定義User對(duì)象,給這個(gè)對(duì)象新增一個(gè)contact屬性,它包含著User的phone。。

const User = {
  name: '搞前端的半夏',
  age: '18',
  contact:{
    phone:'110',
  }
}

如果我們用.的當(dāng)時(shí)來(lái)回去phone的值,則需要兩次.

const phone = User.contact.phone;

如果使用解構(gòu)賦值的話:則寫法如下:

const  {contact:{phone}}=User
consosle.log(phone)  // 輸出10.

無(wú)論是多少層的嵌套,只要按照這個(gè)寫法,一定會(huì)拿到具體的值。

使用對(duì)象解構(gòu)定義一個(gè)新變量以及默認(rèn)值

默認(rèn)值

當(dāng)然我們?cè)谌粘i_發(fā)的過(guò)程中,可能會(huì)遇到很多極端的情況,

例如后端傳過(guò)來(lái)的對(duì)象,可能會(huì)缺失某些字段

const User = {
  name: '搞前端的半夏',
}

或者屬性沒有具體的值:

const User = {
  name: '搞前端的半夏',
  age: ''
}

當(dāng)我們使用解構(gòu)賦值的話:無(wú)論是否存在age屬性的話,都會(huì)創(chuàng)建age變量。

const { name, age } = employee;

當(dāng)User.age沒有具體值得話,我們則可以使用

const { name, age=18 } = employee;

給age一個(gè)默認(rèn)值。

新變量

堅(jiān)持,稍等。解構(gòu)部分有更多的魔力展示!如何創(chuàng)建一個(gè)全新的變量并分配一個(gè)使用對(duì)象屬性值計(jì)算的值?聽起來(lái)很復(fù)雜?這是一個(gè)例子,

當(dāng)我們想輸出User屬性的組合值的話,應(yīng)該怎么做呢?

const { name,age,detail = `${name} 今年 ${age} `} = User ;
console.log(detail); // 輸出:搞前端的半夏 今年 18 

使用 JavaScript 對(duì)象解構(gòu)別名

在 JavaScript 對(duì)象解構(gòu)中,您可以為解構(gòu)變量alias命名。減少變量名沖突的機(jī)會(huì)非常方便。

const User = {
  name: '搞前端的半夏',
  age: ''
}

假設(shè)我們想用解構(gòu)賦值獲取age屬性的值,但是代碼中已經(jīng)又age這個(gè)變量了,我們這個(gè)時(shí)候就需要在結(jié)構(gòu)的時(shí)候定義別名。

const { age: userAge } = User;
console.log(userAge); //搞前端的半夏

而如果使用age的話,會(huì)報(bào)錯(cuò)。

console.log(age);

使用對(duì)象解構(gòu)處理動(dòng)態(tài)名稱屬性

我們經(jīng)常將 API 響應(yīng)數(shù)據(jù)作為 JavaScript 對(duì)象處理。這些對(duì)象可能包含動(dòng)態(tài)數(shù)據(jù),因此作為客戶端,我們甚至可能事先不知道屬性鍵名稱。

const User = {
  name: '搞前端的半夏',
  age: ''
}

當(dāng)我們將鍵作為參數(shù)傳遞時(shí),我們可以編寫一個(gè)返回User對(duì)象屬性值的函數(shù)。這里我們使用了[],來(lái)接受參數(shù),js會(huì)根據(jù)這個(gè)鍵對(duì)從對(duì)象中檢索!

function getPropertyValue(key) {
    const { [key]: returnValue } = User;   
    return returnValue;
}
const contact = getPropertyValue('contact');
const name = getPropertyValue('name');

console.log(contact, name); // 空  搞前端的半夏

在函數(shù)參數(shù)和返回值中解構(gòu)對(duì)象

解構(gòu)賦值傳參

使用對(duì)象解構(gòu)將屬性值作為參數(shù)傳遞給函數(shù)。

const User = {
  name: '搞前端的半夏',
  age: 18
}

name現(xiàn)在讓我們創(chuàng)建一個(gè)簡(jiǎn)單的函數(shù),該函數(shù)使用和屬性值創(chuàng)建一條消息dept以登錄到瀏覽器控制臺(tái)。

function consoleLogUser({name, age}) {
  console.log(`${name} 今年 ${age}`); 
}

直接將值作為函數(shù)參數(shù)傳遞并在內(nèi)部使用它們。

consoleLogUser(User); // 搞前端的半夏 今年 18

解構(gòu)函數(shù)對(duì)象返回值

對(duì)象解構(gòu)函數(shù)還有另一種用法。如果函數(shù)返回一個(gè)對(duì)象,您可以將值直接解構(gòu)為變量。讓我們創(chuàng)建一個(gè)返回對(duì)象的函數(shù)。

function getUser() {
  return {
    'name': '搞前端的半夏',
    'age': 18
  }
}
const { age } = getUser();
console.log(age); // 18

在循環(huán)中使用對(duì)象解構(gòu)

我們將討論的最后一個(gè)(但并非最不重要的)用法是循環(huán)解構(gòu)。讓我們考慮一組員工對(duì)象。我們想要遍歷數(shù)組并想要使用每個(gè)員工對(duì)象的屬性值。

const User= [
  { 
       'name': '愛分享的半夏',
   		 'age': 16
  },
  { 
      'name': '搞前端的半夏',
   		 'age': 18
  },
  { 
        'name': '敲代碼的半夏',
   		 'age': 20
  }
];

您可以使用for-of循環(huán)遍歷User對(duì)象,然后使用對(duì)象解構(gòu)賦值語(yǔ)法來(lái)檢索詳細(xì)信息。

for(let {name, age} of employees) {
  console.log(`${name} 今年${age}歲!!!`);
}

總結(jié)

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

相關(guān)文章

  • 深入淺析JavaScript中with語(yǔ)句的理解

    深入淺析JavaScript中with語(yǔ)句的理解

    JavaScript 有個(gè) with 關(guān)鍵字, with 語(yǔ)句的原本用意是為逐級(jí)的對(duì)象訪問提供命名空間式的速寫方式。這篇文章主要介紹了JavaScript中with語(yǔ)句的相關(guān)知識(shí),感興趣的朋友一起學(xué)習(xí)吧
    2016-05-05
  • ES6中export?default和export之間的區(qū)別詳解

    ES6中export?default和export之間的區(qū)別詳解

    export和export?default都是es6語(yǔ)法中用來(lái)導(dǎo)出組件的,可以導(dǎo)出的文檔類型有(?數(shù)據(jù)、常量、函數(shù)、js文件、模塊等),下面這篇文章主要給大家介紹了關(guān)于ES6中export?default和export之間的區(qū)別的相關(guān)資料,需要的朋友可以參考下
    2023-04-04
  • js設(shè)置控件的隱藏與顯示的兩種方法

    js設(shè)置控件的隱藏與顯示的兩種方法

    js設(shè)置控件的隱藏與顯示,設(shè)置控件style的display和visibility屬性就可以了,下面有個(gè)示例,需要的朋友可以參考下
    2014-08-08
  • 給自定義對(duì)象加上自定義事件的支持的教程

    給自定義對(duì)象加上自定義事件的支持的教程

    自從我寫了幾個(gè)還可以拿出手的東東之后,自我感覺牛B了許多,還有不少同志圍著我,稱我為高手,虛容心大大的得到了滿足。這些是后話,暫且不表。。。
    2008-03-03
  • 開啟BootStrap學(xué)習(xí)之旅

    開啟BootStrap學(xué)習(xí)之旅

    當(dāng)下最流行的前端開發(fā)框架Bootstrap,可大大簡(jiǎn)化網(wǎng)站開發(fā)過(guò)程,從而深受廣大開發(fā)者的喜歡,你如果也喜歡Bootstrap前端開發(fā)框架,不要錯(cuò)過(guò)這次旅行
    2016-05-05
  • JS前端輕松導(dǎo)出Excel的通用方法詳解

    JS前端輕松導(dǎo)出Excel的通用方法詳解

    這篇文章主要介紹關(guān)于導(dǎo)出Excel通用方法的實(shí)用前端技巧,希望能夠幫助大家更好地處理數(shù)據(jù)導(dǎo)出需求,接下來(lái),我將為大家詳細(xì)介紹這個(gè)方法和代碼實(shí)現(xiàn),需要的朋友可以參考下
    2023-09-09
  • javascript實(shí)現(xiàn)表格信息增添與刪除

    javascript實(shí)現(xiàn)表格信息增添與刪除

    這篇文章主要為大家詳細(xì)介紹了javascript實(shí)現(xiàn)表格信息增添與刪除,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2021-04-04
  • JavaScript實(shí)現(xiàn)的購(gòu)物車效果可以運(yùn)用在好多地方

    JavaScript實(shí)現(xiàn)的購(gòu)物車效果可以運(yùn)用在好多地方

    JavaScript實(shí)現(xiàn)的購(gòu)物車效果,當(dāng)然這個(gè)效果可以運(yùn)用在好多地方,比如好友的選擇,人力資源模塊等等,需要的朋友可以參考下
    2014-05-05
  • JavaScript設(shè)計(jì)模式之工廠模式和構(gòu)造器模式

    JavaScript設(shè)計(jì)模式之工廠模式和構(gòu)造器模式

    這篇文章主要介紹了JavaScript設(shè)計(jì)模式之工廠模式和構(gòu)造器模式,本文同時(shí)講解了設(shè)計(jì)模式的類別如創(chuàng)建型設(shè)計(jì)模式、結(jié)構(gòu)型設(shè)計(jì)模式、行為設(shè)計(jì)模式等內(nèi)容,需要的朋友可以參考下
    2015-02-02
  • JavaScript 定時(shí)器 SetTimeout之定時(shí)刷新窗口和關(guān)閉窗口(代碼超簡(jiǎn)單)

    JavaScript 定時(shí)器 SetTimeout之定時(shí)刷新窗口和關(guān)閉窗口(代碼超簡(jiǎn)單)

    這篇文章主要介紹了JavaScript 定時(shí)器 SetTimeout之定時(shí)刷新窗口和關(guān)閉窗口(代碼超簡(jiǎn)單)的相關(guān)資料,需要的朋友可以參考下
    2016-02-02

最新評(píng)論