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

首頁 > 開發 > JS > 正文

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

2024-05-06 16:52:21
字體:
來源:轉載
供稿:網友

前言

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,可以做到這一點。但是在輕量級前端項目中,特別是如果你只需要這些庫中的一兩個方法時,最好選擇另一個輕量級庫,或者編寫自己的庫。

總結

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


注:相關教程知識閱讀請移步到JavaScript/Ajax教程頻道。
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
日韩视频欧美视频| 国产中文欧美精品| 久久久久久国产精品美女| 午夜精品蜜臀一区二区三区免费| 日韩av在线一区| 亚洲一区二区三区视频播放| 日韩在线观看免费全集电视剧网站| 国产精品入口免费视| 国产精品com| 3344国产精品免费看| 国产精品视频免费观看www| 午夜精品一区二区三区在线视频| 中文字幕在线观看日韩| 欧美电影第一页| 久久久久久久久91| 欧美另类高清videos| 中文字幕久久久av一区| 久久综合网hezyo| 精品国产网站地址| 亚洲国产成人91精品| 国产精品成人免费视频| 日韩欧美一区二区三区| 久久中国妇女中文字幕| 欧美亚洲在线视频| 久久精品99国产精品酒店日本| 色先锋久久影院av| 欧美精品电影在线| 欧美日韩亚洲精品一区二区三区| 亚洲欧洲第一视频| 日韩欧美中文字幕在线播放| 色噜噜狠狠狠综合曰曰曰88av| 成人啪啪免费看| 97成人超碰免| 亚洲国产精彩中文乱码av| 亚洲成人久久网| 最新日韩中文字幕| 色综合久久中文字幕综合网小说| 日韩在线一区二区三区免费视频| 日本免费在线精品| 97人人爽人人喊人人模波多| 国产美女搞久久| 在线观看91久久久久久| 中文字幕日韩欧美| 欧美又大又硬又粗bbbbb| 久久精品久久久久电影| 久久成人一区二区| 北条麻妃在线一区二区| 午夜精品久久久99热福利| 国产精品视频网站| 精品国产一区二区在线| 国产99久久精品一区二区| 亚洲最大福利视频网站| 日韩av最新在线| 黄网动漫久久久| 久久精品夜夜夜夜夜久久| 亚洲人成在线电影| 国产精品久久久久免费a∨| 久久人人爽亚洲精品天堂| 亚洲美女又黄又爽在线观看| 国产欧美日韩91| 国产成+人+综合+亚洲欧洲| 91亚洲国产成人精品性色| 日韩av片免费在线观看| 亚洲大尺度美女在线| 亚洲人成在线观看网站高清| 中文字幕一区二区三区电影| 欧美一区三区三区高中清蜜桃| 一道本无吗dⅴd在线播放一区| 国产最新精品视频| 国内精品久久久久久影视8| 日本免费久久高清视频| 91极品女神在线| 亚洲第一二三四五区| 91人人爽人人爽人人精88v| 欧美一级黑人aaaaaaa做受| 久久av资源网站| 欧美极品少妇xxxxⅹ喷水| 日韩欧美在线国产| 精品亚洲永久免费精品| 亚洲成人网在线观看| 97精品欧美一区二区三区| 欧美国产极速在线| 国产欧美韩国高清| 日韩精品欧美国产精品忘忧草| 亚洲成在人线av| 日本91av在线播放| 亚洲精品一区中文字幕乱码| 日韩欧美在线字幕| 日本一区二区在线播放| 日韩麻豆第一页| 欧美精品情趣视频| 国产精品日韩专区| 久久国产精品久久久久久| 黄色成人av在线| 欧美成人黄色小视频| 亚洲人成伊人成综合网久久久| 欧美怡春院一区二区三区| 成人春色激情网| 欧美在线视频一区| 97精品国产97久久久久久| 青青精品视频播放| 国产欧美中文字幕| 欧美一级黑人aaaaaaa做受| 国产一区二区视频在线观看| 国产一级揄自揄精品视频| 国产成人精品久久亚洲高清不卡| 成人免费视频97| 日韩av不卡电影| 国产日韩精品在线| 亚洲一区二区中文字幕| 亚洲成人精品av| www.午夜精品| 91理论片午午论夜理片久久| 色吧影院999| 一区二区av在线| 欧美国产日韩一区二区| 亚洲激情在线观看| 色婷婷亚洲mv天堂mv在影片| 国产精品都在这里| 国产精品久久97| 91最新国产视频| 亚洲影视中文字幕| 欧美精品在线看| 777777777亚洲妇女| 日韩av一区二区在线| 成人高清视频观看www| 欧美激情区在线播放| 国产精品福利小视频| 懂色aⅴ精品一区二区三区蜜月| 精品亚洲一区二区| 欧美日韩国产第一页| 亚洲欧美日韩精品| 97免费视频在线播放| 欧美日韩精品在线观看| 法国裸体一区二区| 91在线观看免费观看| 国产成人在线视频| 在线观看免费高清视频97| 亚洲欧洲免费视频| 国产日产久久高清欧美一区| 久久精品国产亚洲7777| 亚洲欧美日韩精品久久| 欧美成人手机在线| 成人免费网视频| 国产精品高清在线观看| 成人美女免费网站视频| 成人免费观看a| 日韩中文字幕亚洲| 亚洲精品日韩欧美| 久久影视三级福利片| 日韩在线观看免费高清完整版| 欧美激情亚洲自拍| 国产成人亚洲精品| 欧美日韩一区二区免费视频| 日韩美女毛茸茸| 久久夜色撩人精品| 欧美另类69精品久久久久9999| 久久免费视频在线观看| 成人精品视频99在线观看免费| 亚洲一区二区中文字幕| 日韩中文字幕国产| 国产精品视频永久免费播放| 久久久人成影片一区二区三区| 欧美有码在线视频|