时间:2021-05-26
本文实例讲述了javascript设计模式 – 外观模式原理与用法。分享给大家供大家参考,具体如下:
介绍:外观模式是一种使用频率非常高的结构型设计模式,它通过引入一个外观角色来简化客户端与子系统之间的交互,为复杂的子系统调用提供一个统一的入口,隐藏系统复杂度,降低子系统与客户端的耦合度。
定义:为子系统中的一组接口提供一个统一的入口。外观模式定义了一个高层接口,这个接口使得这一子系统更加容易使用。
场景:我们还是用画圆的方式来介绍下外观模式。
示例:
var Rectangle = function(){ this.draw = function(){ console.log('画一个矩形'); }} var Circle = function(){ this.draw = function(){ console.log('画一个圆'); }} var Triangle = function(){ this.draw = function(){ console.log('画一个三角形'); }} var ShapeMaker = function(){ this.rectangle = new Rectangle(); this.circle = new Circle(); this.triangle = new Triangle(); this.drawRectangle = function(){ this.rectangle.draw(); } this.drawCircle = function(){ this.circle.draw(); } this.drawTriangle = function(){ this.triangle.draw(); }} var shapeMaker = new ShapeMaker(); shapeMaker.drawRectangle(); //画一个矩形shapeMaker.drawCircle(); //画一个圆shapeMaker.drawTriangle(); //画一个三角形是不是豁然开朗?其实我们日常最常用的就是外观模式。我们的工具类,jquery,包括一些浏览器兼容,我们都会把他们封装到一个对象里。
这就是外观模式提倡的把复杂的操作封装到一个简单接口中。几乎所有的涉及多个业务对象交互的场景都可以考虑使用外观模式进行重构。
外观模式总结:
优点:
* 对客户端屏蔽了子系统组件,减少了客户端所需处理的对象数目,并且提升使用便捷度。
* 实现了客户端与子系统之间的松耦合关系,这使得子系统的变化不会影响客户端。
缺点:
* 不能姮好的限制客户端直接使用子系统类
* 如果设计不当,增加新的子系统可能需要修改外观类的源代码,违背了开关原则
适用场景:
* 需要对一个复杂子系统提供一个简单入口时可以采用外观模式
感兴趣的朋友可以使用在线HTML/CSS/JavaScript代码运行工具:http://tools.jb51.net/code/HtmlJsRun测试上述代码运行效果。
更多关于JavaScript相关内容感兴趣的读者可查看本站专题:《javascript面向对象入门教程》、《JavaScript错误与调试技巧总结》、《JavaScript数据结构与算法技巧总结》、《JavaScript遍历算法与技巧总结》及《JavaScript数学运算用法总结》
希望本文所述对大家JavaScript程序设计有所帮助。
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
本文实例讲述了javascript设计模式–模板方法模式原理与用法。分享给大家供大家参考,具体如下:介绍:模板方法模式是结构最简单的行为型设计模式,在其结构中只
本文实例讲述了javascript设计模式–迭代器模式原理与用法。分享给大家供大家参考,具体如下:介绍:迭代器模式是一种使用频率非常高的设计模式,通过引入迭代器
本文实例讲述了javascript设计模式–命令模式原理与用法。分享给大家供大家参考,具体如下:介绍:命令模式是一种数据驱动的设计模式,将请求以命令的形式包裹在
本文实例讲述了javascript设计模式–代理模式原理与用法。分享给大家供大家参考,具体如下:介绍:代理使我们很常见的一众模式,proxy,nginx都称之为
本文实例讲述了javascript设计模式–中介者模式原理与用法。分享给大家供大家参考,具体如下:介绍:在前端开发的过程中,组件与组件之间的通讯特别常见,一个组