中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

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

發布時間:2020-09-23 10:21:56 來源:腳本之家 閱讀:132 作者:前端小智 欄目:web開發

前言

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

總結

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

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

大宁县| 榆中县| 临安市| 洛川县| 武强县| 色达县| 芒康县| 宜章县| 太和县| 新源县| 云阳县| 锡林郭勒盟| 古田县| 安多县| 招远市| 天柱县| 怀柔区| 专栏| 奉贤区| 呼图壁县| 三穗县| 繁峙县| 静安区| 新田县| 安龙县| 获嘉县| 西峡县| 龙州县| 乐山市| 东安县| 甘南县| 连云港市| 牡丹江市| 滦平县| 台中市| 成都市| 安图县| 四会市| 宜丰县| 曲靖市| 晋城|