JS基础--with改变作用域

with通常被当做重复引用同一对象中的多个属性的快捷方式。可以不需要重复引用对象本身。

一个例子引发的思考:

function foo(obj){
with(obj){
a=2;
}
}
var o1=
{a:2}
var o2={b:3}
foo(o1);
console.log(o1.a)//2
foo(02);
console.log(o2.a)//undefined
console.log(a)//2
我们可以注意到一个奇怪的副作用,a=2赋值操作实际上创建了一个全局变量a,

with可以将一个没有或有多个属性的对象处理为一个完全隔离的词法作用域,因此这个对象的属性也会被处理为定义在这个作用域中的标识符。

尽管with块可以将一个对象处理为词法作用域,但是这个块内部正常的var声明并不会被限制在这个块的作用域当中,而是被添加到with所处的函数作用域。

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值