[Javascript] How javascript read the property?

As we know we can read property value from an object as so:

const obj = {}

obj.xxxx;
obj[xxxx];

 

So what's the difference between those two?

 

obj.x

ECMAScript will do a transform internally as such

[[GET]](obj /*object itself*/, 'x' /*property key*/, obj /*this pointer*/)

 

obj[x]

ECMAScript will do a transform internally as such

[[GET]](
    obj /*object itself*/, 
    x is symbol ? x: String(x) /*check whether x is symbol, if is, then use symbol, otherwise stringify x*/, 
    obj /*this pointer*/
)

 

So as we can see, the only difference between those two is how ECMAScript handle x property key.

obj.x: consider 'x' as string value

obj[x]: consider x can be smybol or not, if yes, will use symbol, otherwise, convert to string value

 

Examples

const obj = {}
obj[0] = 1 // is 0 a symbol? nope, then conver to '0'
obj['0'] = 2 // is '0' a symbol? nope, then keep '0'
console.log(obj) // {'0': 2}

 

const obj = {}

obj[obj] = 1 // is obj a symbol? nope, then String(obj) which is '[object object]'
console.log(obj) // {'[object Object]': 1}

 

 

const obj = {
  toString() {
    return 'abc'
  }
}

obj[obj] = 1 // is obj a symbol? nope, then String(obj) which is 'abc'
console.log(obj) // {toString: [Function: toString], 'abc': 1}

 

posted @   Zhentiw  阅读(4)  评论(0编辑  收藏  举报
相关博文:
阅读排行:
· 阿里最新开源QwQ-32B,效果媲美deepseek-r1满血版,部署成本又又又降低了!
· Manus重磅发布:全球首款通用AI代理技术深度解析与实战指南
· 开源Multi-agent AI智能体框架aevatar.ai,欢迎大家贡献代码
· 被坑几百块钱后,我竟然真的恢复了删除的微信聊天记录!
· AI技术革命,工作效率10个最佳AI工具
历史上的今天:
2020-10-08 [Postgres] On conflict Do Something Clause in Postgres
2020-10-08 [React] Debug Custom React Hooks With useDebugValue
2019-10-08 [NgRx] Optimistically Editing Entity Data
2019-10-08 [Angular 8] Keep original DOM structure with ng-container
2019-10-08 [NgRx 8] Basic of NgRx8
2016-10-08 [NodeJS] Use Now alias for custom sub-domains
2016-10-08 [CSS3] Create a fixed-fluid-fixed layout using CSS calc()
点击右上角即可分享
微信分享提示