首页 >> js开发 >> js代码javascript设计模式 – 外观模式原理与用法实例分析
js代码javascript设计模式 – 外观模式原理与用法实例分析
发布时间: 2021年1月13日 | 浏览:
| 分类:js开发
本文实例讲述了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(); //画一个三角形
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./code/HtmlJsRun测试上述代码运行效果。在线HTML/CSS/JavaScript代码运行工具在线HTML/CSS/JavaScript代码运行工具http://tools./code/HtmlJsRun关于JavaScript相关内容感兴趣的读者可查看本站专题:《javascript面向对象入门教程》、《JavaScript错误与调试技巧总结》、《JavaScript数据结构与算法技巧总结》、《JavaScript遍历算法与技巧总结》及《JavaScript数学运算用法总结》javascript面向对象入门教程JavaScript错误与调试技巧总结JavaScript数据结构与算法技巧总结JavaScript遍历算法与技巧总结JavaScript数学运算用法总结希望本文所述对大家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(); //画一个三角形
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./code/HtmlJsRun测试上述代码运行效果。在线HTML/CSS/JavaScript代码运行工具在线HTML/CSS/JavaScript代码运行工具http://tools./code/HtmlJsRun关于JavaScript相关内容感兴趣的读者可查看本站专题:《javascript面向对象入门教程》、《JavaScript错误与调试技巧总结》、《JavaScript数据结构与算法技巧总结》、《JavaScript遍历算法与技巧总结》及《JavaScript数学运算用法总结》javascript面向对象入门教程JavaScript错误与调试技巧总结JavaScript数据结构与算法技巧总结JavaScript遍历算法与技巧总结JavaScript数学运算用法总结希望本文所述对大家JavaScript程序设计有所帮助。
相关文章:
- js微信小程序动态评分展示/五角星展示/半颗星展示/自定义长度展示功能的实现js大全
- js解决echarts中横坐标值显示不全(自动隐藏)问题js大全
- js详解微信小程序入门从这里出发(登录注册、开发工具、文件及结构介绍)js大全
- js解决Vue中的生命周期beforeDestory不触发的问题js大全
- jsvue中解决拖拽改变存在iframe的div大小时卡顿问题js大全
- jsvue中destroyed方法的使用说明js大全
- js在vue中created、mounted等方法使用小结js大全
- jseslint+prettier统一代码风格的实现方法js大全
- js解决Vue router-link绑定事件不生效的问题js大全
- jsvue 清空input标签 中file的值操作js大全