javascript 判读对象属性

发布于 2022-09-01 16:04:38 字数 77 浏览 22 评论 0

如下
var test={name:"Jack"};
这两种有区别么 test.name 和 test["name"]

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。

评论(3

老街孤人 2022-09-08 16:04:38

由于test.name和test["name"]规范定义均为Property Accessor,并且定义访问Property Accessor的运算过程为
对test.name或test["name"]进行运算得到类型为Reference的中间变量,数据结构为
{
base: test,
propertyName: "name",
useStrict: false
}
然后再通过内部方法[[GetValue]]或[[PutValue]]处理中间变量
而从test.name或test["name"]到Reference实例的过程是parser处理的,而运行时对test.name和test['name']无感知,因此实质上是无区别的。
但由于点方式中属性名必须遵循identifier的命名规范,而下标方式方式中则采用StringLiteral,所以下标方式方式中属性命名的字符集更广泛。

因为看清所以看轻 2022-09-08 16:04:38

这两种都是访问对象属性的方式,其结果是一样的,差别就是[]方式更通用一点,比如属性名是 "my name",那就只能用 [] 访问了,即 test['my name']

此刻的回忆 2022-09-08 16:04:38

这2种都可以访问到对象的属性

比较常见的一种区别就是,如果你要设置对象的某个属性是用变量来定义的,那么不能使用 obj.x的方式,而是需要使用 obj[x]的方式获取属性值,因为前一种js会认为你是给obj对象赋予一个叫x的属性

~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文