对象取值.和[]的区别

在学习ts过程中 使用泛型加上keyof约束对象的属性类型时  发现了传入泛型的方法不能直接使用obj.xxx来读取对象的属性 但是obj[xxx]的方式可以  如下图 👇

 首先先明确一下定义

在js中 可以使用obj.xxx和obj[xxx]的方式访问对象的属性

但是如果访问对象的方法 就只能使用obj.xxx的方式

如果我们取的值是一个静态值 那么通常使用obj.xxx 但是如果是动态属性 那么obj[xxx]更好

如下图👇

 如图 他们都能获取到对象中的值

但是不同的是: 

[ ]运算符可以使用字符串变量的内容作为属性名,点运算符不能

[ ]运算符可以用纯数字作为属性名,点运算符不能

[ ]运算符可以用js关键字和保留字作为属性名,点运算符不能

总结:obj.xxx适合直接访问对象中的静态属性 因为obj.xxx会直接去对象中寻找xxx属性 并不会读取变量

let object = {
    name: 'zzz',
    age: 18
}
let value = 'name'
// console.log(object.value);  //报错
console.log(object[value]);  //读取到了

总之 对于常量可以直接使用obj.xxx的方式来进行访问修改   对于其他形式 比如数字作为键名或者通过变量转换键名的方式的 可以用obj[xxx]的方式来进行访问

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值