本文实例讲述了JavaScript组合模式。分享给大家供大家参考,具体如下:
首先:
使用一个例子来引入组合模式,需求为
(1)有一个学校有2个班(一班,二班)
(2)每个班级分2个小组(一班一组,一班二组,二班一组,二班二组)
(3)学校计算机教室有限,每一个小组分着来上课
然后:根据需求我们可以简单看出这里面涉及到 学校,班级,组,和学生总共4个类
使用程序模拟 这4个类为,
(1)学校类
var school=function (name) { this.name=name; var classes=new Array(); this.addClasses=function (cla) { classes.push(classe); } this.getClass=function () { return classes; } }
(2)班级类
//班级类 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)组类
//组 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)学生类
//学生类 var student=function (name) { this.name=name; this.gotoClass=function () { document.write(name+":我是学生,我要去上课 ") }; this.finishClass=function () { document.write(name+": 终于下课了"); } };
其次,测试需满足如下为:
(1)每个班级分2个小组(一班一组,一班二组,二班一组,二班二组)
(2)学校计算机教室有限,每一个小组的学生分着来上课
(3)现在我们倒着写,从学生-->组->班级-->学校
//学生实例 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同学"); //班级实例(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); //学校实例 var usSchool=new school("组合模式学校");
最后,开学了,我们准备按照要求去上课吧,
安排为:一班一组去上课 学校-->班级-->组-->学生
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(); } } } } }
最后,我只是想安排一个都要写这么多的代码,那如何是一个学校有上千个班级,那么要疯了。
这种一定不适合业务的扩展,为此我们使用组合模式来解决上述的问题。
为啥要用设计模式呢?
因为设计模式有如下的一些操作方式:
(1)组合模式中把对象分为两种(组合对象,和叶子对象)
(2)组合对象和叶子对象实现:同一批操作
(3)对组合对象执行的操作可以向下传递到叶子节点进行操作
(4)这样就会弱化类与类之间的耦合
(5)他常用的手法是把对象组合成属性结构的对象
接下来介绍:JavaScript组合设模式--改进上述引入的例子
感兴趣的朋友可以使用在线HTML/CSS/JavaScript代码运行工具:http://tools.jb51.net/code/HtmlJsRun测试上述代码运行效果。
更多关于JavaScript相关内容感兴趣的读者可查看本站专题:《javascript面向对象入门教程》、《JavaScript错误与调试技巧总结》、《JavaScript数据结构与算法技巧总结》、《JavaScript遍历算法与技巧总结》及《JavaScript数学运算用法总结》
希望本文所述对大家JavaScript程序设计有所帮助。
本文向大家介绍JavaScript组合设计模式--改进引入案例分析,包括了JavaScript组合设计模式--改进引入案例分析的使用技巧和注意事项,需要的朋友参考一下 本文实例讲述了JavaScript组合设计模式--改进引入案例。分享给大家供大家参考,具体如下: 对于组合设计模式: (1)组合模式中把对象分为两种(组合对象,和叶子对象) (2)组合对象和叶子对象实现:同一批操作 (3)对组
本文向大家介绍JavaScript设计模式--桥梁模式引入操作实例分析,包括了JavaScript设计模式--桥梁模式引入操作实例分析的使用技巧和注意事项,需要的朋友参考一下 本文实例讲述了JavaScript设计模式--桥梁模式引入操作。分享给大家供大家参考,具体如下: 1.使用情况 (1)事件的监控 #1,利用页面的button来选择宠物的例子(思路) #2,addEvent函数 总结:该种方
本文向大家介绍php桥接模式应用案例分析,包括了php桥接模式应用案例分析的使用技巧和注意事项,需要的朋友参考一下 本文实例讲述了php桥接模式应用。分享给大家供大家参考,具体如下: 桥接模式是将抽象部分与它的实现部分分离,使它们都可以独立地变化。 示例: 当一个信息时 根据发送渠道分为:QQ消息、email消息、短信消息等 根据消息类型分为:普通、警告、危急等 每种消息都有三种类型(普通QQ消息
本文向大家介绍React组件设计模式之组合组件应用实例分析,包括了React组件设计模式之组合组件应用实例分析的使用技巧和注意事项,需要的朋友参考一下 本文实例讲述了React组件设计模式之组合组件应用。分享给大家供大家参考,具体如下: 这种模式本质上解决的是组件之间传值的问题。但是它对于传值以及一些内部操控的逻辑封装得更严密。 场景:希望减少上下级组件之间props的传递,简单来说就是不用传做显
本文向大家介绍javascript组合使用构造函数模式和原型模式实例,包括了javascript组合使用构造函数模式和原型模式实例的使用技巧和注意事项,需要的朋友参考一下 本文实例讲述了javascript组合使用构造函数模式和原型模式的方法。分享给大家供大家参考。具体如下: 希望本文所述对大家的javascript程序设计有所帮助。
主要内容:介绍,实现,Employee.java,CompositePatternDemo.java组合模式(Composite Pattern),又叫部分整体模式,是用于把一组相似的对象当作一个单一的对象。组合模式依据树形结构来组合对象,用来表示部分以及整体层次。这种类型的设计模式属于结构型模式,它创建了对象组的树形结构。 这种模式创建了一个包含自己对象组的类。该类提供了修改相同对象组的方式。 我们通过下面的实例来演示组合模式的用法。实例演示了一个组织中员工的层次结构。 介绍 意图:将对象组合