位置: 编程技术 - 正文

JavaScript 设计模式之组合模式解析(js设计模式有什么用)

编辑:rootadmin
怎么说呢?!就像是动物(组合对象)一样,当它生下后代(叶对象)时,它的后代就有了某种功能(比如:挖洞,听力好等等);也像是一棵树,它有一个根(组合对象)然后是从这个棵树向外冒出的其他枝杆(组合对象)以及从这些枝杆又向外长的叶子(叶对象)。换句话说,就是当祖先已经有了,那么只要从这个祖先衍生出来的其他孩子(包括这个祖先下的其他组合对象)已经就具备了某种功能,看上去貌似又有些像是继承。“组合模式”在组合对象的层次体系中有两种类型的对象:叶对象和组合对象。组合模式擅长于对大批对象进行操作。 “组合模式”就是在做一个项目的时候,我们要把在这个项目中即将出现的方法都在组合对象中定义(包括叶对象中的方法),而它们的叶对象将会继承组合对象。当组合对象被实例化后其叶对象的方法也相应地被实例化了。可能我说的有些乱,下面就用一个例子来说明吧。 “组合模式”是一种专为创建Web上的动态用户界面而量身定制的模式。使用这种模式,可以用一条命令在多个对象上激发复杂的或递归的行为。 使用“组合模式”可以为我们带来两大好处: 1、可以用同样的方法处理对象的集合与其中的特定子对象。 2、可以用来把一批子对象组织成树形结构,并且使整棵树都可以被遍历。 只有同时具备以下两个条件进才适合使用组合模式: 1、存在一批组织成某处层次体系的对象(具体结构可能在开发期间无法知道)。 2、希望对这批对象或其中的一部分对象实话一个操作。 下面看一下示例: 具体要求是做一个图片库且可以有选择地隐藏或显示图片库的特定部分。这可能是单独图片,也可能是图片库。现在就需要两个类来完成这个功能:用作图片库的组合对象类和用于图片本身的叶对象类,代码如下: 在上面的代码中,首先定义的是组合对象类和叶对象类应该实现的接口。除了常规的组合远景一分钱上,这些类要怕硬欺软 操作只包括hide和show。接下来我们定义叶对象。叶对象实现hide和show,代码如下: 以下是设置叶对象的相应方法: 这是一个演示组合模式的工作方式的例子。每个类都很简单,但由于有了这样一种层次体系,我们就可以执行一些复杂操作。GalleryImage类的构造函数会创建一个image元素。这个类定义中的其余部分由空的组合对象方法(因为这是叶结点)和GalleryItem要求的操作组成。现在我们可以使用这两个类来管理图片: 组合模式之利,使用组合模式,简单的操作也能产生复杂的结果。不必编写大师手工遍历数组或其他数据结构的粘合代码,只需对最顶层的对象执行操作,主每一个子对象自己传递这个操作即可。这对于那些再三执行的操作尤其有用。在组合模式中,各个对象之间的耦合非常松散。每当对顶层组合对象执行一个操作时,实际上是在对整个结构进行尝试优先的搜索以查找节点。 组合模式之弊,由于对组合模式调用的任何操作都会被颇佳北至 它的所有子对象,如果这个层次体系很大的话,系统的性能将会受到影响。

推荐整理分享JavaScript 设计模式之组合模式解析(js设计模式有什么用),希望有所帮助,仅作参考,欢迎阅读内容。

JavaScript 设计模式之组合模式解析(js设计模式有什么用)

文章相关热门搜索词:js设计模式有哪几种,js设计模式有哪些,js设计模型,js设计模型,js设计模式应用,js设计模式应用,JAVASCRIPT设计模式与开发实践,JAVASCRIPT设计模式与开发实践,内容如对您有帮助,希望把文章链接给更多的朋友!

javascript 对象入门实例教程 1:构造函数法[Ctrl+A全选注:如需引入外部Js需刷新才能执行]注解:1:这里定义了一个Dog对象(在javascript中,函数就是对象,这里functionDog(name,weight)同时

JavaScript之信息的封装 js对象入门 JavaScript之信息的封装在编码前,我们需要了解如下几个术语;封装:对内部数据的表现形式和实施细节进行隐藏;私有属性和方法:外界只能通过其公

javascript 设计模式之单体模式 面向对象学习基础 单体模式(singleton)单体是在脚本加载时创建的,能将一系列有关联的变量和方法组织为一个逻辑单元,逻辑单元里面的内容通过单一的变量进行访问

标签: js设计模式有什么用

本文链接地址:https://www.jiuchutong.com/biancheng/386537.html 转载请保留说明!

上一篇:javascript 单例模式演示代码 javascript面向对象编程(js编写一个标准的单例模式类)

下一篇:javascript 对象入门实例教程(js中对象)

  • 车辆保险的车船税怎么算
  • 个体户没做过账怎么办
  • 未达起征点的增值税怎么做账
  • 存货的期末余额在借方还是贷方
  • 建筑公司可以开机械租赁发票吗
  • 盈余公积补亏为什么未分配利润增加
  • 出差飞机票报销标准
  • 农产品是零税率还是免税税率
  • 简易计征怎么开票
  • 发票开成了下属机构的可以报销吗
  • 农产品进项抵扣政策
  • 负债表内容
  • 购房契税应该交给谁
  • 销售的增值税怎么算
  • 企业固定资产折旧当月增加当月计提吗
  • 预提职工福利怎么记账
  • 租赁合同印花税计税依据
  • 主营业务收入包含消费税吗
  • 速达财务软件使用说明
  • 预付账款收不回来摘要怎么写
  • 园林绿化工程公司有哪些
  • 床垫专票可以抵扣吗
  • 可引导的macos
  • 流动资产固定资产和无形资产都是资产类账户
  • 金税三期怎么更正申报
  • 微信支付被限制是怎么回事
  • antd怎么用
  • edge弹窗
  • 预计资产未来现金流量的期限
  • 企业向银行贷款要交印花税吗
  • macos big sur值得升级吗
  • 融资租赁账务处理实例承租方
  • 契税发票遗失怎么处理
  • 红字发票负数要怎么抵掉
  • 终止劳动合同赔偿需要缴税吗
  • 日本长野县在哪
  • symerr函数
  • 社保调整基数后 两个月没变化
  • php实现文件的下载
  • 元宇宙区块链数字货币
  • typescript instanceof
  • content security policy blob
  • vgrename命令 重命名卷组
  • thinkphp if
  • 远程调试时,gdbserver运行在调试机
  • 公司的一项专利多少钱
  • 分公司申请独立账户流程
  • 小规模纳税人开票额度
  • 单位收的房租可以发工资吗
  • micro start
  • mysql常用命令行大全
  • 帝国cms栏目自定义字段
  • 公司油票发票信息怎么查
  • 工业企业外购存货的实际成本不包括
  • 软件产品增值税即征即退
  • 怎么看发票的凭证号
  • 班车租赁服务
  • mysql57服务无法启动,找不到文件夹
  • rhel7.2安装
  • 还原精灵使用教程
  • big是什么文件格式
  • centos配置yum
  • Facebook Open Platform编译FAQ
  • win7显示ipv4ipv6无网络访问权限
  • win7磁盘空间不足怎么清理文件
  • shader开发实战
  • webrtc opus
  • ftp命令操作
  • bat读取文件内所有内容
  • angular nz
  • webpack使用场景
  • activity间数据传递
  • qq登录失败是怎么回事
  • python中flask模块
  • 广西国家税务局于红林
  • 地税办理停保
  • 电子税务局申领的发票怎么读入金税盘
  • 广东电子税务局中山税务局网
  • 契税完税证明遗失
  • 天津市东丽区军粮城派出所电话
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

    网站地图: 企业信息 工商信息 财税知识 网络常识 编程技术

    友情链接: 武汉网站建设