JavaScript 设计模式之外观模式
外观模式是为外部提供简单的接口一种方式,由于模块内部方法庞杂,不能一一对外公开,那么我们需要一个统一的和简单的对外方法 API 来调用这些内在的函数。这时候我们可以用到外观模式:
var module = (function(){
var name = 'bobi';
var _p = function() {//内部方法,不公开
console.log('your name is' + name);
}
var _q = function() {//内部方法,不公开
console.log('my name is' + name);
}
var _c = function(m) {//内部方法,不暴露
name = m
}
return{
f : function(m) {//公开的方法
_c(m);//调用私有方法
if(name == 'bobi') {
_p()
}else{
_q();
}
}
}
})();
在 module 中,所有的私有方法都不需要公开,我们只是暴露了一个 f 方法,作为桥接的接口,f 里面会执行调用各个内部方法。我们不需要关系 _q
、_p
的执行内容,只需要关心 f
这个公开的方法。在这里,f
就是作为一个简单的 api 来访问这些方法的。
外观模式也有一些缺点:那就是层级访问带来的性能问题,也就是说本来可以一层执行的函数,现在需要第二层来实现,所以在考虑使用此方法的时候我们要考虑到这样做的好处和付出的代价是否合理。
如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。
绑定邮箱获取回复消息
由于您还没有绑定你的真实邮箱,如果其他用户或者作者回复了您的评论,将不能在第一时间通知您!
发布评论