javascript设计模式 – 桥接模式原理与应用实例分析

作者:李小强 时间:2024-04-26 17:12:09 

本文实例讲述了javascript设计模式 – 桥接模式原理与应用。分享给大家供大家参考,具体如下:

介绍:如果软件系统中某个类存在两个或多个独立变化的维度,可以通过桥接模式将这些维度分离出来,使两者可以独立扩展,让系统更符合单一职责原则。

定义:将抽象部分与其实现部分分离,使他们都可以独立的变化。它是一种对象结构型模式,又称为柄体模式或接口模式。

场景:我们做一个简单的画圆,将圆的半径和颜色这两个维度进行分离,使每一个维度都可以单独扩展,很多同学都说这么简单一个需求我5行代码就实现了。为什么写这么啰嗦一套。
我们这里分享的是设计思想,当你的系统足够复杂时需要用什么样的方式进行优化。作为示例,也只是用最小的例子把道理讲明白,不是说所有类似的地方就必须这么写。什么样的场景需要什么样的模式,需不需要用模式需要你自己去考量。

示例:


var CircularColor = {};
CircularColor.redCircular = function(){
 this.getColor = function(){
   return 'red';
 }
}
CircularColor.greenCircular = function(){
 this.getColor = function(){
   return 'green';
 }
}

var CircularRadius = {};
CircularRadius.small = function(){
 this.x = this.y = 0;
 this.radius = 5;
 this.color = null;
 this.setColor = function(circularColor){
   this.color = circularColor.getColor();
 }
 this.draw = function(){
   console.log('画一个小圆!颜色:' + this.color + ' 原点坐标:x:' + this.x + ' y:' + this.y + ' 半径:' + this.radius);
 }
}
CircularRadius.big = function(){
 this.x = this.y = 0;
 this.radius = 20;
 this.color = null;
 this.setColor = function(circularColor){
   this.color = circularColor.getColor();
 }
 this.draw = function(){
   console.log('画一个大圆!颜色:' + this.color + ' 原点坐标:x:' + this.x + ' y:' + this.y + ' 半径:' + this.radius);
 }
}

var color = new CircularColor.redCircular();
var radius = new CircularRadius.big();
radius.setColor(color);
radius.draw();//画一个大圆!颜色:red 原点坐标:x:0 y:0 半径:20

这节需要说一个点,桥接模式在java的介绍里,独立之后的维度是在抽象层会建立关联关系,js没有抽象层,所以两个独立维度通过一个setColor方法建立关联关系。

桥接模式总结:

优点:

* 桥接模式提高了系统的可扩展性,在两个变化维度中任意扩展一个维度,都不需要修改原有系统,符合开关原则。
* 多数情况下,桥接模式可以取代多层集成方案。
* 分离接口及其实现部分,使得实现可以沿着各自的维度来变化。

缺点:

* 桥接模式的使用会增加系统的理解与设计难度。
* 桥接模式要求正确识别出系统中两个独立变化的维度,因此其使用范围具有一定的局限性。

适用场景:

* 一个类存在两个或多个独立变化的维度,且这些维度都需要独立进行扩展。

希望本文所述对大家JavaScript程序设计有所帮助。

来源:http://www.isjs.cn/?p=972

标签:javascript,设计模式,桥接模式
0
投稿

猜你喜欢

  • Golang Gob编码(gob包的使用详解)

    2024-02-22 02:16:46
  • 小程序登录/注册页面设计的实现代码

    2024-04-18 09:44:10
  • mysql创建数据库,添加用户,用户授权实操方法

    2024-01-14 18:16:58
  • mysql 存在该记录则更新,不存在则插入记录的sql

    2024-01-29 07:19:24
  • ADO组件之插入数据记录

    2008-10-08 12:21:00
  • Pytorch反向求导更新网络参数的方法

    2021-02-07 11:48:52
  • 设计师的幸福

    2009-05-21 11:59:00
  • 网站鼠标变变变!

    2010-10-20 20:09:00
  • python 自动化办公之批量修改文件名实操

    2021-09-21 06:54:45
  • PyTorch中clone()、detach()及相关扩展详解

    2022-06-29 17:50:34
  • Python函数式编程

    2023-12-29 10:58:46
  • python聊天程序实例代码分享

    2021-07-09 13:03:33
  • 原生javascript运动函数的封装示例【匀速、抛物线、多属性的运动等】

    2024-04-25 13:15:33
  • mysql 事务处理及表锁定深入简析

    2024-01-23 06:34:52
  • 使用BULK INSERT大批量导入数据 SQLSERVER

    2012-01-05 19:26:36
  • SQL Server中实现二进制与字符类型之间的数据转换

    2023-07-17 21:34:47
  • Python迭代器iterator生成器generator使用解析

    2023-11-17 18:50:24
  • python实现web应用框架之增加响应对象

    2022-04-08 02:33:37
  • Go语言的数据结构转JSON

    2024-04-25 15:04:23
  • ASP批量生成静态页面的写法(批量生成技巧iframe)

    2011-02-24 11:01:00
  • asp之家 网络编程 m.aspxhome.com