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

溫馨提示×

溫馨提示×

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

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

js獲取對象屬性值的方法怎么使用

發布時間:2023-05-04 15:03:42 來源:億速云 閱讀:75 作者:iii 欄目:開發技術

本篇內容介紹了“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獲取對象屬性值的方法怎么使用”的內容就介紹到這里了,感謝大家的閱讀。如果想了解更多行業相關的知識可以關注億速云網站,小編將為大家輸出更多高質量的實用文章!

向AI問一下細節

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

js
AI

宜阳县| 汝城县| 措勤县| 鲁山县| 开鲁县| 通州区| 丹江口市| 七台河市| 灵台县| 孝昌县| 伊宁县| 汝州市| 九寨沟县| 福建省| 临洮县| 滨州市| 九龙县| 怀安县| 亳州市| 辽源市| 姜堰市| 江川县| 堆龙德庆县| 天祝| 黔西| 得荣县| 鸡东县| 五常市| 武鸣县| 辛集市| 泰顺县| 南京市| 车致| 两当县| 佛冈县| 宿州市| 丰宁| 武清区| 石首市| 景泰县| 邻水|