前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >JavaScript组合模式---引入

JavaScript组合模式---引入

作者头像
wfaceboss
发布2019-04-08 10:52:51
2970
发布2019-04-08 10:52:51
举报
文章被收录于专栏:wfacebosswfaceboss
代码语言:javascript
复制
首先:
使用一个例子来引入组合模式,需求为
(1)有一个学校有2个班(一班,二班)
(2)每个班级分2个小组(一班一组,一班二组,二班一组,二班二组)
(3)学校计算机教室有限,每一个小组分着来上课

然后:根据需求我们可以简单看出这里面涉及到   学校,班级,组,和学生总共4个类
代码语言:javascript
复制
 使用程序模拟  这4个类为,
代码语言:javascript
复制
(1)学校类
代码语言:javascript
复制
  var school=function (name) {
        this.name=name;
        var classes=new Array();
         this.addClasses=function (cla) {
            classes.push(classe);
         }
         this.getClass=function () {
             return classes;
         }
    }
代码语言:javascript
复制

(2)班级类

代码语言:javascript
复制
//班级类
    var  classes=function (name) {
        this.name = name;
        var groups = new Array();
        this.addGroup = function (group) {
            groups.push(group);
            return this;
        };
        this.getGroups = function () {
            return groups;
        }
    };

(3)组类

代码语言:javascript
复制
    //组
    var group=function (name) {
        this.name=name;
        var students=new Array();
        var addStudents=function (student) {
            students.push(student);
            return this;
        }
          this.geStudent=function () {
              return students;
          }
    };

(4)学生类

代码语言:javascript
复制
 //学生类
        var student=function (name) {
            this.name=name;
            this.gotoClass=function () {
                document.write(name+":我是学生,我要去上课 ")
            };
            this.finishClass=function () {
                document.write(name+": 终于下课了");
            }
        };

其次,测试需满足如下为:

代码语言:javascript
复制
(1)每个班级分2个小组(一班一组,一班二组,二班一组,二班二组)
(2)学校计算机教室有限,每一个小组的学生分着来上课
(3)现在我们倒着写,从学生-->组->班级-->学校
代码语言:javascript
复制
代码语言:javascript
复制
 //学生实例
    var  astudent=new student("我是a同学");
    var  bstudent=new student("我是b同学");
    var  cstudent=new student("我是c同学");
    var  dstudent=new student("我是d同学");
    var  estudent=new student("我是e同学");
    var  fstudent=new student("我是f同学");
    var  gstudent=new student("我是g同学");
    var  hstudent=new student("我是h同学");
    var  istudent=new student("我是i同学");
代码语言:javascript
复制
代码语言:javascript
复制
//班级实例(1)
     var class1=new classes("一班");
        //组1
    var oneOne=new group("一班一组");
        //组中添加学生
    oneOne.addStudents(astudent).addStudents(bstudent);
    //组2
    var oneTwo=new group("一班二组");
    //组中添加学生
    oneTwo.addStudents(cstudent).addStudents(dstudent);

    class1.addGroup(oneOne).addGroup(oneTwo);
   //班级实例2
    var class2=new classes("二班");
    //组1
    var towOne=new group("二班一组");
    //组中添加学生
    towOne.addStudents(estudent).addStudents(fstudent);

    //组2
    var towTwo=new group("二班二组");
    //组中添加学生
    towTwo.addStudents(gstudent).addStudents(hstudent).addStudents(istudent);
    //
    class2.addGroup(towOne).addGroup(towTwo);
代码语言:javascript
复制
 //学校实例
    var usSchool=new school("组合模式学校");

最后,开学了,我们准备按照要求去上课吧,

安排为:一班一组去上课 学校-->班级-->组-->学生

代码语言:javascript
复制
 var classes=usSchool.getClass();//班级
       for(var i=0;i<classes.length;i++){
           if(classes[i].name=="一班"){
               for(var j=0;j<classes[i].getGroups().length;j++){
                    if(classes[i].classes[i].getGroups()[j]=="一组"){
                       var students=classes[i].classes[i].getGroups()[j].geStudent();
                       for(var k=0;k<students.length;k++){
                           students[k].gotoClass();
                       }
                    }
               }
           }
       }

最后,我只是想安排一个都要写这么多的代码,那如何是一个学校有上千个班级,那么要疯了。

代码语言:javascript
复制
这种一定不适合业务的扩展,为此我们使用组合模式来解决上述的问题。
为啥要用设计模式呢?
因为设计模式有如下的一些操作方式:
代码语言:javascript
复制
(1)组合模式中把对象分为两种(组合对象,和叶子对象)
 (2)组合对象和叶子对象实现:同一批操作
 (3)对组合对象执行的操作可以向下传递到叶子节点进行操作
 (4)这样就会弱化类与类之间的耦合
 (5)他常用的手法是把对象组合成属性结构的对象
代码语言:javascript
复制
请开阅读下篇:JavaScript组合设模式--改进上述引入的例子
代码语言:javascript
复制
本文参与 腾讯云自媒体分享计划,分享自作者个人站点/博客。
原始发表:2017-10-18 ,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档