您好,登錄后才能下訂單哦!
本篇內容介紹了“js獲取對象屬性值的方法怎么使用”的有關知識,在實際案例的操作過程中,不少人都會遇到這樣的困境,接下來就讓小編帶領大家學習一下如何處理這些情況吧!希望大家仔細閱讀,能夠學有所成!
場景:已知對象的某屬性,我們需要獲取對象中的屬性值
js獲取對象屬性值的方法
通過 . 獲取
通過 [ ] 獲取
let person = { name: "bob", age: 18 }; // 通過 [] 獲取 bob console.log(person['name']); // 加引號,識別為屬性去對象中查找 // 通過 . 獲取 bob console.log(person.name);
接下來介紹一下兩種方法的不同點
[ ]運算符可以用數字作為屬性名,點運算符不能
let p = { 1: 'Alex', 2: 33 } console.log(p[1]); // Alex console.log(person.1); // 報錯 Uncaught SyntaxError: missing ) after argument list
[ ]運算符可以用變量作為屬性名,點運算符不能
let person = { name: "bob", age: 18 }; let key = 'name'; console.log(person[key]); // bob 不加引號,識別為變量 console.log(person.key); // undefined
ps:
用變量key獲取對象中的屬性值時,點運算符會將key視為一個屬性去對象中查找,對象中沒有這個屬性,因此為undefined
在用 [ ] 獲取值時,需要注意的是 [ ] 中是否要加引號
補充:可選鏈運算符 ?.
可選鏈運算符(?.)允許讀取位于連接對象鏈深處的屬性的值,而不必明確驗證鏈中的每個引用是否有效。?. 運算符的功能類似于 . 鏈式運算符,不同之處在于,在引用為空 (nullish ) (null 或者 undefined) 的情況下不會引起錯誤,該表達式短路返回值是 undefined。與函數調用一起使用時,如果給定的函數不存在,則返回 undefined。
我們在訪問對象中一個深度嵌套的子屬性,需要驗證之間的引用,如:
let nestedProp = obj.first && obj.first.second
為了避免報錯,在訪問obj.first.second之前,要保證 obj.first 的值既不是 null,也不是 undefined。如果只是直接訪問 obj.first.second,而不對 obj.first 進行校驗,則有可能拋出錯誤。
有了可選鏈運算符(?.),在訪問 obj.first.second 之前,不再需要明確地校驗 obj.first 的狀態,再并用短路計算獲取最終結果:
let nestedProp = obj.first?.second;
“js獲取對象屬性值的方法怎么使用”的內容就介紹到這里了,感謝大家的閱讀。如果想了解更多行業相關的知識可以關注億速云網站,小編將為大家輸出更多高質量的實用文章!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。