Effective JavaScript Item 10 避免使用with

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

 

Item 9:避免使用withkeyword

 

重点:

  1. 设计withkeyword本来是为了让代码变简洁,可是却起到了相反的效果。比方:

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. 避免使用withkeyword
  2. 对于频繁使用的对象,使用尽可能简短的变量名
  3. 显式地绑定object上的propertylocal variable,而不是使用with


原文地址:https://www.cnblogs.com/yutingliuyl/p/6770556.html