国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 語言 > JavaScript > 正文

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

2024-05-06 15:37:54
字體:
來源:轉載
供稿:網友

前言

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            
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表

圖片精選

主站蜘蛛池模板: 桑日县| 清丰县| 兴化市| 东兰县| 宝清县| 达拉特旗| 天气| 芜湖市| 怀化市| 固原市| 库尔勒市| 临朐县| 临夏市| 新河县| 彩票| 凤城市| 浮山县| 四会市| 东台市| 密云县| 临澧县| 孟村| 康保县| 蒙山县| 沅江市| 安多县| 许昌市| 梅州市| 宣城市| 蓬莱市| 文登市| 安阳县| 舞阳县| 鹤壁市| 宽甸| 阿城市| 寿宁县| 宾川县| 泊头市| 巨鹿县| 策勒县|