揭示 JavaScript 的“with”语句超越其陷阱的潜在好处
经常被怀疑的 JavaScript 的“with”语句确实提供了仔细使用时的实际应用。正如 Alan Storm 富有洞察力的反馈所证明的那样,让我们探索“with”证明其价值的实例。
创建块作用域变量
在引入“let”之前在 ES6 中,JavaScript 缺乏真正的块作用域。这种障碍可能会导致循环内意外的变量冲突,例如以下代码:
for (var i=0; i<3; ++i) { var num = i; setTimeout(function() { alert(num); }, 10); }
但是,使用“with”,我们可以有效地模拟块作用域:
for (var i=0; i<3; ++i) { with ({num: i}) { setTimeout(function() { alert(num); }, 10); } }
这里,循环的每次迭代都有自己的离散“num”变量,解决了变量的问题冲突。
其他合法用例
除了块作用域的潜力之外,“with”语句在各种情况下都有用处:
简化对象访问:“with”允许简洁访问嵌套对象属性:
with(obj) { console.log(name + " is " + age + " years old."); }
管理私有实例变量:可以使用“with”增强封装,在对象内创建伪私有实例变量:
function Person(name, age) { with(this) { this.name = name; this.age = age; } }
强调“with”应该是至关重要的谨慎使用,因为它的潜在缺点可能很大。谨慎地使用它并清楚地了解其含义可确保其收益大于风险。通过采用这些合法的用例,开发人员可以利用 JavaScript 中“with”的力量,同时减少其陷阱。
以上是何时以及为何应使用 JavaScript 的'with”语句?的详细内容。更多信息请关注PHP中文网其他相关文章!