很久以前,我看到有人用如下代码封装了整个 JavaScript 块:
(function() {
// ...
})(this);
问题:
- 上面的代码正确吗?
- 像上面提到的那样封装整个 JavaScript 块有什么好处?
对,那是正确的。它称为自调用匿名函数表达式。
JavaScript 变量具有函数作用域或全局作用域。没有块作用域。将代码封装在自调用函数(如示例中的函数)中,会为一次性使用、立即运行的代码创建临时本地作用域,而不会污染全局命名空间。
考虑以下:
<html>
<body>
...
<script>
(function() {
var x = '';
function myFunction () {
alert('Hello: ' + x);
}
x = 'Bob';
myFunction();
alert(typeof x); // string
alert(typeof myFunction); // function
})();
alert(typeof x); // undefined
alert(typeof myFunction); // undefined
</script>
<script src="other-javascript.js"></script>
</body>
</html>
无论您在该自调用函数中声明什么,都保存在单独的作用域中。变量x
和函数myFunction()
无法从其他任何地方访问。代码在other-javascript.js
例如,不会看到它们,并且可以自由地声明另一个函数myFunction()
没有冲突。
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)