JavaScript组合模式---引入案例分析


Posted in Javascript onMay 23, 2020

本文实例讲述了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.3water.com/code/HtmlJsRun测试上述代码运行效果。

希望本文所述对大家JavaScript程序设计有所帮助。

Javascript 相关文章推荐
Add Formatted Data to a Spreadsheet
Jun 12 Javascript
jquery ajax提交整个表单元素的快捷办法
Mar 27 Javascript
javascript实现百度地图鼠标滑动事件显示、隐藏
Apr 02 Javascript
javascript 使用for循环时该注意的问题-附问题总结
Aug 19 Javascript
JQuery实现的按钮倒计时效果
Dec 23 Javascript
js判断登陆用户名及密码是否为空的简单实例
May 16 Javascript
JS中常用的正则表达式
Sep 29 Javascript
详解React-Router中Url参数改变页面不刷新的解决办法
May 08 Javascript
vue和webpack安装命令详解
Jun 15 Javascript
Vue 路由 过渡动效 数据获取方法
Jul 31 Javascript
JS原型与继承操作示例
May 09 Javascript
详解使用WebPack搭建React开发环境
Aug 06 Javascript
JavaScript设计模式--桥梁模式引入操作实例分析
May 23 #Javascript
JavaScript设计模式--简单工厂模式实例分析【XHR工厂案例】
May 23 #Javascript
JavaScript设计模式--简单工厂模式定义与应用案例详解
May 23 #Javascript
基于element-ui封装可搜索的懒加载tree组件的实现
May 22 #Javascript
微信小程序点击滚动到指定位置的实现
May 22 #Javascript
使用JavaScript通过前端发送电子邮件
May 22 #Javascript
uni-app微信小程序登录授权的实现
May 22 #Javascript
You might like
php引用地址改变变量值的问题
2012/03/23 PHP
PHP获取ttf格式文件字体名的方法示例
2019/03/06 PHP
jQuery 核心函数以及jQuery对象
2010/03/23 Javascript
jQuery事件绑定与解除绑定实现方法
2015/04/15 Javascript
使用微信小程序开发前端【快速入门】
2016/12/05 Javascript
JavaScript获取当前时间向前推三个月的方法示例
2017/02/04 Javascript
vue2组件实现懒加载浅析
2017/03/29 Javascript
jQuery实现上传图片前预览效果功能
2017/08/03 jQuery
vue组件实现进度条效果
2018/06/06 Javascript
用react-redux实现react组件之间数据共享的方法
2018/06/08 Javascript
在Bootstrap开发框架中使用dataTable直接录入表格行数据的方法
2018/10/25 Javascript
微信小程序tabbar底部导航
2018/11/05 Javascript
Vue.js组件高级特性实例详解
2018/12/24 Javascript
如何从0开始用node写一个自己的命令行程序
2018/12/29 Javascript
详解javascript函数写法大全
2019/03/25 Javascript
基于vue-draggable 实现三级拖动排序效果
2020/01/10 Javascript
[19:14]DOTA2 HEROS教学视频教你分分钟做大人-维萨吉
2014/06/24 DOTA
python 读写中文json的实例详解
2017/10/29 Python
解决pandas使用read_csv()读取文件遇到的问题
2018/06/15 Python
对python3 一组数值的归一化处理方法详解
2018/07/11 Python
Python 中的参数传递、返回值、浅拷贝、深拷贝
2019/06/25 Python
浅析Python+OpenCV使用摄像头追踪人脸面部血液变化实现脉搏评估
2019/10/17 Python
Python接口测试文件上传实例解析
2020/05/22 Python
pycharm实现猜数游戏
2020/12/07 Python
浅谈CSS3中的变形功能-transform功能
2017/12/27 HTML / CSS
HTML5 Video/Audio播放本地文件示例介绍
2013/11/18 HTML / CSS
菲律宾优惠券网站:MetroDeal
2019/04/12 全球购物
护理学毕业生求职信
2013/11/14 职场文书
2014年百日安全生产活动总结
2014/05/04 职场文书
社区维稳工作方案
2014/06/06 职场文书
小学竞选班长演讲稿
2014/09/09 职场文书
在职证明书范本(2014新版)
2014/09/25 职场文书
公司员工违纪检讨书
2015/05/05 职场文书
文明和谐家庭事迹材料(2016精选版)
2016/02/29 职场文书
JavaScript实现两个数组的交集
2022/03/25 Javascript
Django框架中模型的用法
2022/06/10 Python