美文网首页
组合模式

组合模式

作者: 卡卡卡卡颂 | 来源:发表于2017-04-02 21:01 被阅读0次

组合模式的作用

组合模式将对象组成树形结构,以表示'整体-部分'的结构。利用对象的多态性统一对待组合对象和单个对象。
树结构的节点分为组合节点和叶节点。叶节点下面不会再有节点,组合节点下面可能还有其他组合节点和叶节点。

什么时候使用组合模式

  1. 表示对象的部分-整体层次结构。
  2. 客户希望统一对待树中的所有对象。

例子:扫描文件夹


    //folder是组合节点
    var Folder=function(name) {
      this.name=name;
      this.files=[];
    }
    
    Folder.prototype.add=function(file) {
      this.files.push(file);
    }
    
    Folder.prototype.scan=function() {
      console.log('开始扫描文件夹:',this.name);
      for (var i=0;i<this.files.length;i++) {
          this.files[i].scan();
      }
    }
    
    //file是叶节点
    var File=function(name) {
      this.name=name;
    }
    
    File.prototype.add =function() {
      throw new Error('文件下面不能再添加文件');
    }
    
    File.prototype.scan=function() {
      console.log('当前文件名:',this.name);
    }
    
    //使用
    var folder1=new Folder('所有资料');
    var folder2=new Folder('生活资料');
    var folder3=new Folder('工作资料');
    
    var file1=new File('数学');
    var file2=new File('语文');
    var file3=new File('钻木取火');
    var file4=new File('nodeJs从入门到放弃');
    
    folder1.add(file1);
    folder1.add(file2);
    folder2.add(file3);
    folder3.add(file4);
    folder1.add(folder2);
    folder1.add(folder3);
    
    folder1.scan();


值得注意的地方

  1. 组合模式不是父子关系,而是一种(HAS-A)聚合关系。
  2. 对一组叶对象的操作必须具有一致性。也就是说不能对某个叶对象单独操作,要一视同仁。
  3. 为️防止一个叶节点关联到多个组合对象,需要建立组合节点和叶节点的双向映射关系。

保持叶节点和组合节点的关联。比如在组合模式中使用职责链时,有可能需要让请求从子节点往父节点上冒泡传递。当我们删除某个文件时,实际是从这个文件所在的上层文件夹中删除这个文件。


    var Folder=function(name) {
      this.name=name;
      this.parent=null;
      this.files=[];
    }
    
    Folder.prototype.add=function(file) {
      this.files.push(file);
      file.parent=this;
    }
    
    Folder.prototype.scan=function() {
      console.log('开始扫描文件夹:',this.name);
      for (var i=0;i<this.files.length;i++) {
          this.files[i].scan();
      }
    }
    
    Folder.prototype.rmove=function() {
        //根节点
      if (!this.parent) {
          return;
      }
      for (var files=this.parent.files,i=files.length-1;i>=0;i--) {
          var file=files[i];
          if (file===this) {
              files.splice(i,1);
          }
      }
    }
    
    var File=function(name) {
      this.name=name;
      this.parent=null;
    }
    
    File.prototype.add=function() {
      throw new Error('不能添加在文件下面');
    }
    
    File.prototype.scan=function() {
      console.log('扫描到文件:',this.name);
    }
    
    File.prototype.remove=function() {
      if (!this.parent) {
            return;
        }
        for (var files=this.parent.files,i=files.length-1;i>=0;i--) {
            var file=files[i];
            if (file===this) {
                files.splice(i,1);
            }
        }
    }

相关文章

  • 设计模式:组合模式 职责链模式

    组合模式 职责链模式 组合模式 组合模式将对象组合成树形结构,以表示“部分-整体”的层次结构。 在组合模式的树形结...

  • 第4章 结构型模式-组合模式

    一、组合模式简介 二、组合模式的优缺点 三、组合模式的使用场景 、组合模式的实例

  • 组合模式(统一叶子与组合对象)

    目录 从生活场景出发,映射组合模式 组合模式的理论概念 组合模式的实现 组合模式在源码中的应用 组合 “优于” 继...

  • 组合模式

    1. 组合模式 1.1 组合模式的定义 组合模式(Composite): 又称部分-整体模式, 将对象组合成树形结...

  • 组合模式

    设计模式系列7--组合模式 《Objective-c 编程之道 iOS 设计模式解析》 - 组合模式 常见组合模式...

  • 设计模式 | 组合模式及典型应用

    本文的主要内容: 介绍组合模式 示例 组合模式总结 源码分析组合模式的典型应用java.awt中的组合模式Java...

  • 组合模式

    一、组合模式介绍 二、组合模式代码实例

  • 组合模式

    设计模式之组合模式 什么是组合模式? 组合模式允许你将对象组合成树形结构来表现”部分-整体“的层次结构,使得客户以...

  • 15、组合模式(Composite Pattern)

    1. 组合模式 1.1 简介   Composite模式,即组合模式,又叫部分整体模式。Composite模式将对...

  • 组合模式原型解析

    组合模式定义: 组合模式,将对象组合成树形结构以表示“部分-整体”的层次结构,组合模式使得用户对单个对象和组合对象...

网友评论

      本文标题:组合模式

      本文链接:https://www.haomeiwen.com/subject/xrzgottx.html