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

在JavaScript中如何訪問暫未存在的嵌套對(duì)象

 更新時(shí)間:2019年06月18日 08:58:32   作者:前端小智  
這篇文章主要給大家介紹了關(guān)于在JavaScript中如何訪問暫未存在的嵌套對(duì)象的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家學(xué)習(xí)或者使用JavaScript具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面來一起學(xué)習(xí)學(xué)習(xí)吧

前言

JavaScript 是個(gè)很神奇的東西。但是 JavaScript中的一些東西確實(shí)很奇怪,讓人摸不著頭腦。其中之一就是當(dāng)你試圖訪問嵌套對(duì)象時(shí),會(huì)遇到這個(gè)錯(cuò)誤

Cannot read property 'foo' of undefined

在大多數(shù)情況下,處理嵌套的對(duì)象,通常我們需要安全地訪問最內(nèi)層嵌套的值。 來個(gè)粟子:

const user = {
  id: 101,
  email: 'jack@dev.com',
  personalInfo: {
    name: 'Jack',
    address: {
      line1: 'westwish st',
      line2: 'washmasher',
      city: 'wallas',
      state: 'WX'
    }
  }
}

當(dāng)我們要訪問user里面的name及city時(shí),我們會(huì)這樣寫。

const name = user.personalInfo.name;
const userCity = user.personalInfo.address.city;

這是簡(jiǎn)單而直接的。

但是,由于某種原因,user 中的 personal不可用,對(duì)象結(jié)構(gòu)將是這樣的:

const user = {
  id: 101,
  email: 'jack@dev.com'
}

現(xiàn)在,如果你在試著訪問 name ,將會(huì)得到一個(gè) Cannot read property 'name' of undefined 的錯(cuò)誤。

const name = user.personalInfo.name; // Cannot read property 'name' of undefined

這是因?yàn)槲覀冊(cè)噲D訪問對(duì)象中不在的 key 為 name 的屬性。

大多數(shù)開發(fā)人員處理這種情況的常用方法如下,

const name = user && user.personalInfo ? user.personalInfo.name : null;

如果你的嵌套結(jié)構(gòu)很簡(jiǎn)單,這是可以的,但是如果數(shù)據(jù)嵌套五或六層深,那么你的代碼就會(huì)看起很混亂:

let city;
if (
  data && data.user && data.user.personalInfo &&
  data.user.personalInfo.addressDetails &&
  data.user.personalInfo.addressDetails.primaryAddress
  ) {
  city = data.user.personalInfo.addressDetails.primaryAddress;
}

有一些技巧可以處理這種混亂的對(duì)象結(jié)構(gòu)。

Oliver Steele的嵌套對(duì)象訪問模式

這是我個(gè)人的最愛,因?yàn)樗勾a看起來干凈簡(jiǎn)單。 我從 stackoverflow 中選擇了這種風(fēng)格,一旦你理解它是如何工作的,它就非常吸引人了。

const name = ((user || {}).personalInfo || {}).name;

使用這種表示法,永遠(yuǎn)不會(huì)遇到無法讀取未定義的屬性“name”。做法是檢查用戶是否存在,如果不存在,就創(chuàng)建一個(gè)空對(duì)象,這樣,下一個(gè)級(jí)別的鍵將始終從存在的對(duì)象訪問。

不幸的是,你不能使用此技巧訪問嵌套數(shù)組。

使用數(shù)組Reduce訪問嵌套對(duì)象

Array reduce 方法非常強(qiáng)大,可用于安全地訪問嵌套對(duì)象。

const getNestedObject = (nestedObj, pathArr) => {
  return pathArr.reduce((obj, key) =>
    (obj && obj[key] !== 'undefined') ? obj[key] : null, nestedObj);
}

// 將對(duì)象結(jié)構(gòu)作為數(shù)組元素傳入
const name = getNestedObject(user, ['personalInfo', 'name']);

// 要訪問嵌套數(shù)組,只需將數(shù)組索引作為數(shù)組元素傳入。.
const city = getNestedObject(user, ['personalInfo', 'addresses', 0, 'city']);
// 這將從 addresses 中的第一層返回 city

Typy

如果你認(rèn)為上面的方法太過非主流,那么可以使用 Typy庫(kù)。除了安全訪問嵌套對(duì)象之外,它還可以做很多很棒的事情。

如果使用Typy,代碼將如下所示

import t from 'typy';

const name = t(user, 'personalInfo.name').safeObject;
const city = t(user, 'personalInfo.addresses[0].city').safeObject;
// address is an array

這里還有一些其他的庫(kù),如 Lodash 和 Ramda,可以做到這一點(diǎn)。但是在輕量級(jí)前端項(xiàng)目中,特別是如果你只需要這些庫(kù)中的一兩個(gè)方法時(shí),最好選擇另一個(gè)輕量級(jí)庫(kù),或者編寫自己的庫(kù)。

總結(jié)

以上就是這篇文章的全部?jī)?nèi)容了,希望本文的內(nèi)容對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,謝謝大家對(duì)腳本之家的支持。

相關(guān)文章

  • 微信小程序 scroll-view的使用案例代碼詳解

    微信小程序 scroll-view的使用案例代碼詳解

    這篇文章主要介紹了微信小程序 scroll-view的使用案例分析,本文通過實(shí)例代碼給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2020-06-06
  • 提高JavaScript執(zhí)行效率的23個(gè)實(shí)用技巧

    提高JavaScript執(zhí)行效率的23個(gè)實(shí)用技巧

    JavaScript是一門非常流行的編程語言,許多開發(fā)者都會(huì)把JavaScript選為入門語言,本文向大家分享JavaScript提高執(zhí)行效率的小技巧、最佳實(shí)踐等非常實(shí)用的內(nèi)容
    2017-03-03
  • JavaScript實(shí)現(xiàn)表格點(diǎn)擊排序的方法

    JavaScript實(shí)現(xiàn)表格點(diǎn)擊排序的方法

    這篇文章主要介紹了JavaScript實(shí)現(xiàn)表格點(diǎn)擊排序的方法,可實(shí)現(xiàn)點(diǎn)擊頂部數(shù)據(jù)項(xiàng)標(biāo)題實(shí)現(xiàn)對(duì)應(yīng)數(shù)據(jù)列的排序效果,涉及javascript鼠標(biāo)事件及數(shù)據(jù)排序的技巧,需要的朋友可以參考下
    2015-05-05
  • 原生JS實(shí)現(xiàn)的放大鏡特效示例【測(cè)試可用】

    原生JS實(shí)現(xiàn)的放大鏡特效示例【測(cè)試可用】

    這篇文章主要介紹了原生JS實(shí)現(xiàn)的放大鏡特效,涉及javascript事件響應(yīng)及頁面元素動(dòng)態(tài)操作相關(guān)實(shí)現(xiàn)技巧,需要的朋友可以參考下
    2018-12-12
  • javascript中文本框中輸入法切換的問題

    javascript中文本框中輸入法切換的問題

    這篇文章主要是對(duì)javascript中文本框中輸入法切換的問題進(jìn)行了詳細(xì)的分析介紹,需要的朋友可以過來參考下,希望對(duì)大家有所幫助
    2013-12-12
  • 解析Javascript單例模式概念與實(shí)例

    解析Javascript單例模式概念與實(shí)例

    本文將介紹Javascript模式中較為常見和實(shí)用的模式——單例模式,主要分為概念和實(shí)例部分。在介紹實(shí)例的同時(shí)也會(huì)對(duì)代碼中額外的知識(shí)點(diǎn)進(jìn)行講解。需要的朋友可以看下
    2016-12-12
  • JavaScript中使用Async實(shí)現(xiàn)異步控制

    JavaScript中使用Async實(shí)現(xiàn)異步控制

    async提供了很多函數(shù)用于異步流程控制,下面是async核心的幾個(gè)函數(shù),大家通過本文學(xué)習(xí)下,對(duì)使用async 實(shí)現(xiàn)異步控制相關(guān)知識(shí),感興趣的朋友一起看看吧
    2017-08-08
  • Echarts中X軸/Y軸坐標(biāo)標(biāo)簽顯示不下的問題解決

    Echarts中X軸/Y軸坐標(biāo)標(biāo)簽顯示不下的問題解決

    本文主要介紹了Echarts中X軸/Y軸坐標(biāo)標(biāo)簽顯示不下的問題解決,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2023-09-09
  • 使用開源工具制作網(wǎng)頁驗(yàn)證碼的方法

    使用開源工具制作網(wǎng)頁驗(yàn)證碼的方法

    這篇文章主要介紹了使用開源工具制作網(wǎng)頁驗(yàn)證碼的方法的相關(guān)資料,非常不錯(cuò),具有參考借鑒價(jià)值,需要的朋友可以參考下
    2016-10-10
  • JS+CSS實(shí)現(xiàn)電子商務(wù)網(wǎng)站導(dǎo)航模板效果代碼

    JS+CSS實(shí)現(xiàn)電子商務(wù)網(wǎng)站導(dǎo)航模板效果代碼

    這篇文章主要介紹了JS+CSS實(shí)現(xiàn)電子商務(wù)網(wǎng)站導(dǎo)航模板效果代碼,涉及JavaScript結(jié)合css動(dòng)態(tài)操作頁面元素屬性的相關(guān)技巧,非常具有實(shí)用價(jià)值,需要的朋友可以參考下
    2015-09-09

最新評(píng)論