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 相关文章推荐
Jquery多选下拉列表插件jquery multiselect功能介绍及使用
May 24 Javascript
SuperSlide2实现图片滚动特效
Jun 20 Javascript
Javascript实现Web颜色值转换
Feb 05 Javascript
jQuery标签编辑插件Tagit使用指南
Apr 21 Javascript
JS验证邮件地址格式方法小结
Dec 01 Javascript
AngularJS入门教程之ng-checked 指令详解
Aug 01 Javascript
基于jQuery实现数字滚动效果
Jan 16 Javascript
H5手机端多文件上传预览插件
Apr 21 Javascript
Vue2.0 实现移动端图片上传功能
May 30 Javascript
react实现antd线上主题动态切换功能
Aug 12 Javascript
在vue-cli3中使用axios获取本地json操作
Jul 30 Javascript
vue3.0 的 Composition API 的使用示例
Oct 26 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 IN_ARRAY 函数使用注意事项
2010/07/24 PHP
让你成为更出色的PHP开发者的10个技巧
2011/02/25 PHP
Drupal7连接多个数据库及常见问题解决
2014/03/02 PHP
织梦sitemap地图实时推送给百度的教程
2015/08/03 PHP
微信公众号开发之语音消息识别php代码
2016/08/08 PHP
PHP框架Laravel中实现supervisor执行异步进程的方法
2017/06/07 PHP
详解PHP使用Redis存储session时的一个Warning定位
2017/07/05 PHP
php生成word并下载代码实例
2019/03/15 PHP
PHP常用工具函数小结【移除XSS攻击、UTF8与GBK编码转换等】
2019/04/27 PHP
Webkit的跨域安全问题说明
2011/09/13 Javascript
新手快速学习JavaScript免费教程资源汇总
2015/06/25 Javascript
jQuery对html元素的取值与赋值实例详解
2015/12/18 Javascript
Bootstrap安装环境配置教程分享
2016/05/27 Javascript
JS常见算法详解
2017/02/28 Javascript
JavaScript运动框架 解决防抖动问题、悬浮对联(二)
2017/05/17 Javascript
微信小程序 自定义Toast实例代码
2017/06/12 Javascript
详解Angular2组件之间如何通信
2017/06/22 Javascript
vue-cli配置文件——config篇
2018/01/04 Javascript
微信小程序实现点击生成随机验证码
2020/09/09 Javascript
解决vue项目中遇到 Cannot find module ‘chalk‘ 报错的问题
2020/11/05 Javascript
Django实现图片文字同时提交的方法
2015/05/26 Python
Python创建一个空的dataframe,并循环赋值的方法
2018/11/08 Python
python中web框架的自定义创建
2019/09/08 Python
Python将视频或者动态图gif逐帧保存为图片的方法
2019/09/10 Python
Python3 解决读取中文文件txt编码的问题
2019/12/20 Python
如何使用python实现模拟鼠标点击
2020/01/06 Python
python中resample函数实现重采样和降采样代码
2020/02/25 Python
Python学习笔记之装饰器
2020/08/06 Python
CSS3伪类选择器:nth-child()
2009/04/02 HTML / CSS
css3背景图片透明叠加属性cross-fade简介及用法实例
2013/01/08 HTML / CSS
玖熙女鞋美国官网:Nine West
2016/10/06 全球购物
萨克斯第五大道精品百货店: Saks Fifth Avenue
2017/04/28 全球购物
Bibloo荷兰:女士、男士和儿童的服装、鞋子和配饰
2019/02/25 全球购物
与UNIX有关的几个名词
2015/09/17 面试题
运动会运动员赞词
2015/07/22 职场文书
导游词之宁夏贺兰山岩画
2019/11/08 职场文书