我见过 JavaScript 中的几种样式。想知道它们在可读性、优化和变量范围方面的区别。赞成和反对将不胜感激。
方法一:
function MyObj(options) {
this.options = options;
}
MyObj.prototype.getOptions = function() {
return this.options;
};
方法二:
var MyObj = (function() {
function MyObj(options) {
this.options = options;
}
MyObj.prototype.getOptions = function() {
return this.options;
};
return MyObj;
})();
有人曾经说过包装器是用来处理 IE 中的命名函数的。我注意到,通过放置一个包装器,可以将对对象静态 的变量和函数进行划分。
然而,我也遇到过很多人提示包装效率低下或奇怪。 CoffeeScript 也编译为方法 B。那么,当手动编写 JS 时,哪种方法是最佳实践,什么时候应该使用一种方法而不是另一种方法?
最佳答案
第二种是使用模块模式。在这个简化的示例中,没有真正的区别,但是对于变量封装通常应该首选第二个,另外它避免了不必要地污染全局命名空间。
关于javascript - 这两种 JavaScript 样式有什么区别?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/14607404/