组合模式

组合模式的作用

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

什么时候使用组合模式

  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);
            }
        }
    }

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 217,826评论 6 506
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 92,968评论 3 395
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 164,234评论 0 354
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 58,562评论 1 293
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 67,611评论 6 392
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 51,482评论 1 302
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 40,271评论 3 418
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 39,166评论 0 276
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 45,608评论 1 314
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,814评论 3 336
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,926评论 1 348
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,644评论 5 346
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 41,249评论 3 329
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,866评论 0 22
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,991评论 1 269
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 48,063评论 3 370
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,871评论 2 354

推荐阅读更多精彩内容

  • 1 场景问题# 1.1 商品类别树## 考虑这样一个实际的应用:管理商品类别树。 在实现跟商品有关的应用系统的时候...
    七寸知架构阅读 6,014评论 10 59
  • 目录 本文的结构如下: 引言 什么是组合模式 模式的结构 典型代码 代码示例 优点和缺点 适用环境 模式应用 一、...
    w1992wishes阅读 888评论 0 2
  • 继承是is-a的关系。组合和聚合有点像,有些书上没有作区分,都称之为has-a,有些书上对其进行了较为严格区分,组...
    时待吾阅读 459评论 0 1
  • 组合模式 组合模式,将对象组合成树形结构以表示“部分-整体”的层次结构,组合模式使得用户对单个对象和组合对象的使用...
    Binaryify阅读 468评论 0 0
  • 组合多个对象形成树形结构以表示具有“整体—部分”关系的层次结构。组合模式对单个对象(即叶子对象)和组合对象(即容器...
    lyu571阅读 492评论 0 1