动态属性名怎么访问?JS对象动态取值3种实用方法
鈥?strong>鈥嬪紑澶存彁闂€?/strong>鈥?br/> 浣犳槸涓嶆槸缁忓父閬囧埌杩欑鎯呭喌锛熸槑鏄庣煡閬撹鎷垮璞$殑鏌愪釜灞炴€э紝浣嗚繖涓睘鎬у悕鍍忓彉榄旀湳涓€鏍蜂細鑷繁鏀规潵鏀瑰幓銆傛瘮濡備粠鎺ュ彛杩斿洖鐨勬暟鎹瓧娈靛悕甯︾潃鏃堕棿鎴筹紝鎴栬€呰鏍规嵁鐢ㄦ埛杈撳叆鍔ㄦ€佹嫾鎺ュ睘鎬у悕銆傝繖鏃跺€欑敤鐐瑰彿锛?锛夎闂氨鍍忔嬁鍥哄畾閽ュ寵寮€鏃嬭浆闂ㄢ€斺€旀牴鏈悶涓嶅畾鍟婏紒
鍒厡锛佷粖澶╁挶浠氨鎺板紑鎻夌浜嗚閫忚繖涓毦棰橈紝鏁欎綘涓夋嫑鈥?strong>鈥嬪姩鎬佸睘鎬у悕璁块棶澶ф硶鈥?/strong>鈥嬨€備繚璇佷綘瀛﹀畬灏辫兘鐢ㄤ笂锛屽啀涔熶笉鐢ㄥ鐫€鍔ㄦ€佸睘鎬у悕骞茬灙鐪煎暒锛?/p>
绗竴鎷涳細鏂规嫭鍙风粷鏉€鎶€
鈥?strong>鈥嬫牳蹇冨師鐞嗏€?/strong>鈥嬶細鐢ㄥ瓧绗︿覆鍙橀噺褰撻挜鍖欏紑閿?br/> 涓句釜鏍楀瓙馃尠锛屼綘鏈変釜鐢ㄦ埛瀵硅薄锛?/p>
javascript澶嶅埗const user = { '2023_score': 95, mobile: '13812345678' }
鎯宠闂甫骞翠唤鐨勫垎鏁板瓧娈垫€庝箞鍔烇紵杩欐椂鍊欎綘鍙兘浼氶棶锛?code>user.2023_score琛屼笉琛岋紵
鈥?strong>鈥嬬瓟妗堝綋鐒舵槸No锛佲€?/strong>鈥?灞炴€у悕浠ユ暟瀛楀紑澶存椂锛屽繀椤荤敤鏂规嫭鍙疯娉曪細
javascript澶嶅埗const year = 2023 console.log(user[year + '_score']) // 杈撳嚭95
鈥?strong>鈥嬪叧閿偣鈥?/strong>鈥嬶細
- 鏂规嫭鍙烽噷鍙互鏀锯€?strong>鈥嬪瓧绗︿覆鎷兼帴琛ㄨ揪寮忊€?/strong>鈥?/li>
- 鏀寔鍙橀噺銆佽繍绠楄〃杈惧紡锛堟瘮濡?code>'key_' + index锛?/li>
- 鑳藉鐞嗙壒娈婂瓧绗﹀睘鎬у悕锛堝
obj['data-list']
锛?/li>
绗簩鎷涳細璁$畻灞炴€у悕绉樼睄
鈥?strong>鈥嬮€傜敤鍦烘櫙鈥?/strong>鈥嬶細鍒涘缓瀵硅薄鏃跺氨鍔ㄦ€佺敓鎴愬睘鎬у悕
鏈夋椂鍊欏挶浠繛灞炴€у悕閮芥槸涓存椂鍐冲畾鐨勶紝姣斿鏍规嵁鎺ュ彛杩斿洖鏁版嵁鍔ㄦ€佺敓鎴愬瓧娈点€傝繖鏃跺€欏氨瑕佺キ鍑篍S6鐨勮绠楀睘鎬у悕鍔熻兘浜嗐€?/p>
鈥?strong>鈥嬪疄鎴樻渚嬧€?/strong>鈥嬶細
javascript澶嶅埗const dynamicKey = 'currentStatus' const app = { [dynamicKey]: '杩愯涓?, ['ver_' + new Date().getFullYear()]: '2.0.1' } console.log(app.currentStatus) // 杈撳嚭"杩愯涓?
鈥?strong>鈥嬭嚜闂嚜绛斺€?/strong>鈥嬶細
Q锛氳繖鍜屾柟鎷彿璁块棶鏈変粈涔堝尯鍒紵
A锛氳绠楀睘鎬у悕鏄€?strong>鈥嬪湪瀵硅薄鍒涘缓闃舵鈥?/strong>鈥嬪姩鎬佺敓鎴愰敭鍚嶏紝鑰屾柟鎷彿璁块棶鏄€?strong>鈥嬪湪璇诲彇闃舵鈥?/strong>鈥嬪姩鎬佹煡鎵俱€傜浉褰撲簬涓€涓槸鍐欏悕瀛楁椂灏辨悶浜嬫儏锛屼竴涓槸鏌ユ埛鍙f椂鍐嶆悶浜嬫儏銆?/p>
绗笁鎷涳細鍙€夐摼鍙屼繚闄?/h3>
鈥?strong>鈥嬫渶鏂版鍣ㄢ€?/strong>鈥嬶細ES2020鐨勫彲閫夐摼鎿嶄綔绗?.
杩欎釜璇硶绯栦笓娌诲悇绉嶅姩鎬佽闂椂鐨勬姤閿欑劍铏戠棁銆傜壒鍒槸澶勭悊澶氬眰宓屽瀵硅薄鏃讹紝绠€鐩存晳鍛界ɑ鑽夛紒
鈥?strong>鈥嬪姣斿疄楠屸€?/strong>鈥嬶細
浼犵粺鍐欐硶锛?/p>
javascript澶嶅埗// 瀹规槗鎶annot read property 'xxx' of undefined const city = user.info.address.city
鍙€夐摼鍐欐硶锛?/p>
javascript澶嶅埗// 瀹夊叏绯绘暟+10086 const city = user?.info?.address?.city
鈥?strong>鈥嬬壒娈婃妧宸р€?/strong>鈥嬶細
鍜屾柟鎷彿閰嶅悎浣跨敤鏁堟灉鏇翠匠锛?/p>
javascript澶嶅埗const key = 'homeAddress' const address = user?.preferences?.[key]
鈥?strong>鈥嬫敞鎰忕偣鈥?/strong>鈥嬶細
- 闇€瑕佺幇浠f祻瑙堝櫒鎴朆abel杞瘧鏀寔
- 涓嶈兘鐢ㄥ湪瀵硅薄璧嬪€兼搷浣滃乏渚э紙姣斿
obj?.a = 1
浼氭姤閿欙級
鏂规硶瀵规瘮閫熸煡琛?/h3>
鎷涘紡鍚嶇О | 閫傜敤闃舵 | 闃茬炕杞﹁兘鍔?/th> | 娴忚鍣ㄦ敮鎸?/th> |
---|---|---|---|
鏂规嫭鍙?/td> | 灞炴€ц鍙栨椂 | 鈽呪槄鈽呪槅鈽?/td> | 鍏ㄦ敮鎸?/td> |
璁$畻灞炴€у悕 | 瀵硅薄鍒涘缓鏃?/td> | 鈽呪槄鈽呪槄鈽?/td> | ES6+ |
鍙€夐摼 | 澶氬眰宓屽璁块棶鏃?/td> | 鈽呪槄鈽呪槄鈽?/td> | 鐜颁唬娴忚鍣?/td> |
涓汉韪╁潙缁忛獙璋?/h3>
鍒氬紑濮嬬敤鍔ㄦ€佸睘鎬у悕鏃讹紝鎴戝彲娌″皯鎺夊潙閲屻€傝寰楁湁娆$敤obj[鍙橀噺鍚峕
姝绘椿鎷夸笉鍒板€硷紝璋冭瘯鍗婂ぉ鎵嶅彂鐜板彉閲忓€煎眳鐒舵槸鏁板瓧绫诲瀷锛佲€?strong>鈥嬪垝閲嶇偣鈥?/strong>鈥嬶細鏂规嫭鍙烽噷鐨勫彉閲忎細鑷姩杞瓧绗︿覆锛屼絾閬囧埌Symbol绫诲瀷灏变細缈昏溅銆?/p>
鐜板湪鎴戠殑缂栫爜涔犳儻鏄細
- 鍔ㄦ€佸睘鎬у悕缁熶竴鐢ㄥ瓧绗︿覆绫诲瀷鍙橀噺瀛樺偍
- 澶氬眰璁块棶蹇呭姞鍙€夐摼?.淇濆钩瀹?/li>
- 澶嶆潅鍦烘櫙鐢?code>Object.hasOwnProperty鍏堟鏌ュ啀鎿嶄綔
鏈€鍚庤鍙ュぇ瀹炶瘽锛氳繖涓夌鏂规硶娌℃湁缁濆鐨勫ソ鍧忥紝灏卞儚铻轰笣鍒€鍜屾壋鎵嬭閰嶅悎浣跨敤銆備笅娆¢亣鍒板姩鎬佸睘鎬у悕鐨勯棶棰樻椂锛屽厛鍒€ョ潃鍐欎唬鐮侊紝鍋滀笅鏉ユ兂鎯宠鐢ㄥ摢鎷涙渶鍚堥€傗€斺€旇繖涓€濊€冭繃绋嬫瘮姝昏纭儗璇硶閲嶈澶氬暒锛?/p>