揭示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中文網其他相關文章!