亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 編程 > JavaScript > 正文

在JavaScript中如何訪問暫未存在的嵌套對象

2019-11-19 11:19:26
字體:
來源:轉載
供稿:網友

前言

JavaScript 是個很神奇的東西。但是 JavaScript中的一些東西確實很奇怪,讓人摸不著頭腦。其中之一就是當你試圖訪問嵌套對象時,會遇到這個錯誤

Cannot read property 'foo' of undefined

在大多數情況下,處理嵌套的對象,通常我們需要安全地訪問最內層嵌套的值。 來個粟子:

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

當我們要訪問user里面的name及city時,我們會這樣寫。

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

這是簡單而直接的。

但是,由于某種原因,user 中的 personal不可用,對象結構將是這樣的:

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

現在,如果你在試著訪問 name ,將會得到一個 Cannot read property 'name' of undefined 的錯誤。

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

這是因為我們試圖訪問對象中不在的 key 為 name 的屬性。

大多數開發人員處理這種情況的常用方法如下,

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

如果你的嵌套結構很簡單,這是可以的,但是如果數據嵌套五或六層深,那么你的代碼就會看起很混亂:

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

有一些技巧可以處理這種混亂的對象結構。

Oliver Steele的嵌套對象訪問模式

這是我個人的最愛,因為它使代碼看起來干凈簡單。 我從 stackoverflow 中選擇了這種風格,一旦你理解它是如何工作的,它就非常吸引人了。

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

使用這種表示法,永遠不會遇到無法讀取未定義的屬性“name”。做法是檢查用戶是否存在,如果不存在,就創建一個空對象,這樣,下一個級別的鍵將始終從存在的對象訪問。

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

使用數組Reduce訪問嵌套對象

Array reduce 方法非常強大,可用于安全地訪問嵌套對象。

const getNestedObject = (nestedObj, pathArr) => {  return pathArr.reduce((obj, key) =>    (obj && obj[key] !== 'undefined') ? obj[key] : null, nestedObj);}// 將對象結構作為數組元素傳入const name = getNestedObject(user, ['personalInfo', 'name']);// 要訪問嵌套數組,只需將數組索引作為數組元素傳入。.const city = getNestedObject(user, ['personalInfo', 'addresses', 0, 'city']);// 這將從 addresses 中的第一層返回 city

Typy

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

如果使用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

這里還有一些其他的庫,如 Lodash 和 Ramda,可以做到這一點。但是在輕量級前端項目中,特別是如果你只需要這些庫中的一兩個方法時,最好選擇另一個輕量級庫,或者編寫自己的庫。

總結

以上就是這篇文章的全部內容了,希望本文的內容對大家的學習或者工作具有一定的參考學習價值,謝謝大家對武林網的支持。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
欧美极品少妇xxxxⅹ裸体艺术| 欧美性20hd另类| 日韩精品免费在线| 欧美激情小视频| 国产免费久久av| 精品二区三区线观看| 欧美激情在线视频二区| 欧美精品激情在线观看| 亚洲欧美日韩视频一区| 欧美丰满少妇xxxxx| 日韩av免费网站| 国产精品一区电影| 国内精品久久久久久| 国产视频亚洲视频| 日本国产一区二区三区| 韩剧1988免费观看全集| 自拍视频国产精品| 91亚洲精品一区二区| 亚洲va男人天堂| 亚洲国产精品久久91精品| 精品视频9999| 中文字幕亚洲国产| 91精品国产91久久久久久不卡| 亚洲欧美制服第一页| 在线亚洲男人天堂| 中文字幕欧美精品日韩中文字幕| 麻豆成人在线看| 久久九九有精品国产23| 亚洲美女精品成人在线视频| 亚洲国产高清高潮精品美女| 亚洲精品自拍第一页| 国产va免费精品高清在线| 久久成人亚洲精品| 欧美性xxxxxx| 久久久在线视频| 欧美性高潮床叫视频| 亚洲欧美中文日韩v在线观看| 91在线免费网站| 日韩欧美成人网| 在线亚洲午夜片av大片| 亚洲欧美日韩一区在线| 久久久精品免费视频| 精品国产精品三级精品av网址| 亚洲丝袜av一区| 久久精品青青大伊人av| 亚洲女人天堂av| 欧美性猛交xxxx黑人| 久久精品小视频| 欧美综合在线第二页| 色先锋久久影院av| 欧美视频二区36p| 爱福利视频一区| 精品视频在线播放色网色视频| 亚洲iv一区二区三区| 色综合视频网站| 日韩av在线导航| 亚洲天堂日韩电影| 疯狂欧美牲乱大交777| 欧美孕妇孕交黑巨大网站| 国产精品自在线| 国内精品视频在线| 久久影视三级福利片| 欧美日韩国产精品专区| 麻豆乱码国产一区二区三区| 午夜精品福利视频| 成人激情在线播放| 国产性色av一区二区| 精品久久久一区二区| 北条麻妃一区二区三区中文字幕| 97精品在线视频| 国产精品免费久久久久影院| 成人av.网址在线网站| 欧美理论电影在线播放| 影音先锋日韩有码| 国产美女91呻吟求| 日韩欧美亚洲综合| 精品久久久久久久大神国产| 一区二区欧美亚洲| 国产在线精品一区免费香蕉| 国内伊人久久久久久网站视频| 亚洲精品色婷婷福利天堂| www日韩中文字幕在线看| 国产精品久久在线观看| 久久人人97超碰精品888| 精品少妇v888av| 久久影视电视剧免费网站清宫辞电视| 91日韩在线播放| 日韩激情视频在线播放| 午夜精品久久久久久久久久久久| 在线亚洲国产精品网| 国产免费观看久久黄| 亚洲国产高潮在线观看| 国产精品综合网站| 国产中文字幕日韩| 久久精品国产一区| 美女视频黄免费的亚洲男人天堂| 97香蕉超级碰碰久久免费软件| 欧美激情视频一区二区三区不卡| 最近2019中文字幕大全第二页| 国产乱肥老妇国产一区二| www.亚洲一区| 日韩免费在线免费观看| 久热在线中文字幕色999舞| 久久91精品国产| 国产日产久久高清欧美一区| 欧美成人免费在线视频| 欧美国产乱视频| 国产精品羞羞答答| 精品一区二区亚洲| 久久免费国产视频| 中文字幕在线观看亚洲| www.日本久久久久com.| 久久久天堂国产精品女人| 亚洲香蕉伊综合在人在线视看| 97视频在线观看视频免费视频| 亚洲aaa激情| 亚洲国产福利在线| 精品亚洲一区二区三区四区五区| 高清日韩电视剧大全免费播放在线观看| 久久的精品视频| 国产精品成人品| 精品福利免费观看| 最近中文字幕日韩精品| 久久精品国亚洲| 久久久久久999| 久久免费视频观看| 中文字幕日韩精品在线| 欧美国产精品日韩| 国产成人精品日本亚洲专区61| 宅男66日本亚洲欧美视频| 欧美一区三区三区高中清蜜桃| 日韩三级影视基地| 欧美高清视频在线播放| 精品国产一区二区在线| 国内精品模特av私拍在线观看| 亚洲欧洲在线免费| 国产亚洲日本欧美韩国| 国产深夜精品福利| 欧美午夜精品久久久久久浪潮| 欧美裸体xxxx| 亚洲天堂2020| 久久久精品在线观看| 久久av中文字幕| 亚洲精品wwwww| 久久这里有精品| 91系列在线观看| 精品久久香蕉国产线看观看亚洲| 国产成人午夜视频网址| 欧美日韩成人黄色| 久热精品在线视频| 亚洲成人黄色在线| 91福利视频在线观看| 影音先锋欧美精品| 欧美日韩视频免费播放| 亚洲国产天堂网精品网站| 国产精品日韩欧美大师| 欧美日韩一区二区精品| 国产精品国产福利国产秒拍| 亚洲国产精品久久久久秋霞蜜臀| 欧美大全免费观看电视剧大泉洋| 国产99久久精品一区二区 夜夜躁日日躁| 欧美大片免费观看在线观看网站推荐| 一区二区欧美亚洲| 日韩av免费看网站|