这种javascript模块模式的优点是什么?
内容导读
互联网集市收集整理的这篇技术教程文章主要介绍了这种javascript模块模式的优点是什么?,小编现在分享给大家,供广大互联网技能从业者学习和参考。文章包含1087字,纯文字阅读大概需要2分钟。
内容图文
![这种javascript模块模式的优点是什么?](/upload/InfoBanner/zyjiaocheng/660/4151c772a73a4316be37b8de4fa58788.jpg)
因此,我已经写了一段时间的骨干应用程序了,我的模块的结构大致如下:
var AppName = AppName || {};
AppName.Module = {};
AppName.Module.View = Backbone.View.extend({...});
AppName.Module.Model = Backbone.Model.extend({...});
但是我最近偶然发现了这个模块模式:
var AppName = AppName || {};
AppName.Module = (function() {
var View = Backbone.View.extend({...});
var Model = Backbone.Model.extend({...});
return {
View: View,
Model: Model
}
})();
在第二种模式中,您可以定义“私有”方法,这些方法只能从Module范围访问,但是除此之外,在我看来,这通常很难测试.有人可以向我解释为什么某些JavaScript程序员偏向于将第二种方法作为本质上更好的模式吗?
解决方法:
这是因为您可以使用私有变量.例如,我们可以使用该模式定义bob并强制代码使用setName函数更改其名称(即,您不能通过直接访问它来更改值:
var bob = (function(){
var name = "Bob";
return {
setName: function(newName){
name = newName;
},
getName: function(){
return name;
}
}
}());
console.log(bob.getName()); // "Bob"
console.log(bob.name); // undefined
bob.setName("Bobby");
console.log(bob.getName()); // "Bobby"
通过立即执行函数定义,您将获得一个新的作用域,可用于使用闭包“隐藏”行程变量.
内容总结
以上是互联网集市为您收集整理的这种javascript模块模式的优点是什么?全部内容,希望文章能够帮你解决这种javascript模块模式的优点是什么?所遇到的程序开发问题。 如果觉得互联网集市技术教程内容还不错,欢迎将互联网集市网站推荐给程序员好友。
内容备注
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 gblab@vip.qq.com 举报,一经查实,本站将立刻删除。
内容手机端
扫描二维码推送至手机访问。