Effective JavaScript Item 10 避免使用with

本文介绍了JavaScript中with关键字的问题及替代方案,强调了避免使用with的重要性,并提供了代码示例。

本系列作为Effective JavaScript的读书笔记。

 

Item 9:避免使用with关键字

 

重点:

  1. 设计with关键字本来是为了让代码变简洁,但是却起到了相反的效果,比如:

function f(x, y) {
	with (Math) {
		return min(round(x), sqrt(y)); // ambiguous references
	}
}

以上的代码中,调用的minround以及sqrt都是Math上的方法。

如果Math对象上没有以上指定的方法,那么会在with以外的范围去寻找该方法。

 

那么如果Math对象上有两个字段分别是xy


Math.x = 0;
Math.y = 0;
f(2, 9); // 0

可以发现,最后的调用结果是0

 

  1. 编译器也无法对代码做出优化,会降低对property的查找速度
  2. 一个with的替代方案是给变量尽可能短的名字,然后还是使用常规地方式进行操作,比如:

function f(x, y) {
	var min = Math.min, round = Math.round, sqrt = Math.sqrt;
	return min(round(x), sqrt(y));
}

总结:

  1. 避免使用with关键字
  2. 对于频繁使用的对象,使用尽可能简短的变量名
  3. 显式地绑定object上的propertylocal variable,而不是使用with


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值