js的点表示法和方括号表示法

本文探讨了JavaScript中对象属性访问的两种方式:点表示法和方括号表示法。点表示法简洁直观,而方括号表示法则提供了通过变量访问属性的能力,适用于动态属性名场景。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

最近发现了一个很好玩的js特性,就是任何可以用点表示法的语句,都可以同样用方括号表示法表示出来,就例如一下语句,三句都是可以实现的:

document.body.innerHTML="test1";

document.body["innerHTML"]="test12";

document["body"]["innerHTML"]="test123";

一般来说,访问对象属性时都使用点表示法,这也是很多面向对象语言中通用的语法。不过在JavaScript中,也可以使用方括号表示法来访问对象的属性。

var person = {
    name:'david'
}

在使用方括号语法时,应该把属性以字符串的形式放在方括号中,如:

alert(person["name"]);                    //david
alert(person.name);                        //david

虽然点表示法看起来更简洁,在一般情况下是优先选择的方法,但是方括号表示法有着点表示法没有的好处,可以通过变量来访问属性,例如:

var addr="";
for(i=0;i<4;i++){
    addr += customer["address"+i]+'\n';
}

function addStock(portfolio,stockname,shares){
    portfolio[stockname]=shares;
}

但是!!我们建议使用点表示法,除非必须使用变量来访问属性。

转载于:https://www.cnblogs.com/amiezhang/p/javascript.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值