组合模式:将一组对象组合成树形结构,并统一对待组合对象和叶对象,忽略它们之间的不同(因为叶对象也可以也可以包含叶对象而成为组合对象),组合模式中的对象只能是一对多的关系,不能出现多对一。
基本单元:一个组合对象包含多个叶对象。每个基本单元又可以是别的组合对象的叶对象类似文件夹与它里面的内容的关系网,一个文件夹或文件又可以是其它文件夹的内容,但一个文件夹或文件不能同时属于多个上级文件夹。
在JavaScript中实现组合模式时,要保证组合对象和叶对象拥有相同的接口方法,对同一组叶对象的操作必须具有一致性。
例子:
//定义组合对象 var Folder = function (name) { this.name = name; this.parent = null; this.files = []; }; Folder.prototype.add = function (file) { file.parent = this; if(this.files.indexOf(file) === -1){ this.files.push(file); }else{ console.log('\''+file.name+'\'已存在,添加失败'); } }; Folder.prototype.scan = function () { if(this.parent){ console.log('开始扫描\''+this.parent.name+'\': '+this.name); }else{ console.log('开始扫描根目录: '+this.name); } //关键在这里,调用所有它的叶对象的接口方法scan() for(var i = 0, file; file = this.files[i++];){ file.scan(); } }; Folder.prototype.remove = function (file) { var n = this.files.indexOf(file); if(n === -1){console.log('无法删除: \''+file.name+'\'不存在:');} if(n >= 0){ this.files.splice(n,1); console.log('成功删除:'+file.name); } }; //定义叶对象 var File = function (name) { this.name = name; this.parent = null; }; File.prototype.add = function () { console.log('不能添加在文件下面'); }; File.prototype.scan = function () { console.log(this.parent.name+': '+this.name); }; File.prototype.remove = function (file) { console.log('无法删除: \''+file.name+'\'不存在:'); }; //测试 var folder = new Folder('目录'); var folder1 = new Folder('学习质料'); var folder2 = new Folder('javascript'); var file1 = new File('Node.js'); var file2 = new File('qq.jpg'); folder.add(folder1); folder.add(folder1); folder.add(folder2); folder1.add(file1); folder2.add(file2); //'学习质料'添加成功 //'学习质料'已存在,添加失败 //'javascript'添加成功 //'Node.js'添加成功 //'qq.jpg'添加成功 folder.remove(folder1); folder.remove(folder1); file1.remove(file1); //成功删除:学习质料 //无法删除: '学习质料'不存在: //无法删除: 'Node.js'不存在: folder.scan(); //这里相当于执行了一个宏命令 //开始扫描根目录: 目录 //开始扫描'目录': javascript //javascript: qq.jpg
以上所述是小编给大家介绍的JavaScript组合模式,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对网站的支持!
标签:
js,组合模式
免责声明:本站文章均来自网站采集或用户投稿,网站不提供任何软件下载或自行开发的软件!
如有用户或公司发现本站内容信息存在侵权行为,请邮件告知! 858582#qq.com
暂无“JavaScript组合模式学习要点”评论...
稳了!魔兽国服回归的3条重磅消息!官宣时间再确认!
昨天有一位朋友在大神群里分享,自己亚服账号被封号之后居然弹出了国服的封号信息对话框。
这里面让他访问的是一个国服的战网网址,com.cn和后面的zh都非常明白地表明这就是国服战网。
而他在复制这个网址并且进行登录之后,确实是网易的网址,也就是我们熟悉的停服之后国服发布的暴雪游戏产品运营到期开放退款的说明。这是一件比较奇怪的事情,因为以前都没有出现这样的情况,现在突然提示跳转到国服战网的网址,是不是说明了简体中文客户端已经开始进行更新了呢?
更新动态
2024年11月19日
2024年11月19日
- 柏菲·珞叔作品集《金色大厅2》限量开盘母带ORMCD[低速原抓WAV+CUE]
- Gareth.T《sad songs(Explicit)》[320K/MP3][29.03MB]
- Gareth.T《sad songs(Explicit)》[FLAC/分轨][152.85MB]
- 证声音乐图书馆《海风摇曳·盛夏爵士曲》[320K/MP3][63.06MB]
- 龚玥《金装龚玥HQCD》头版限量[WAV分轨]
- 李小春《吻别》萨克斯演奏经典[原抓WAV+CUE]
- 齐秦《辉煌30年24K珍藏版》2CD[WAV+CUE]
- 证声音乐图书馆《海风摇曳·盛夏爵士曲》[FLAC/分轨][321.47MB]
- 群星 《世界经典汽车音乐》 [WAV分轨][1G]
- 冷漠.2011 《冷漠的爱DSD》[WAV+CUE][1.2G]
- 陈明《流金岁月精逊【中唱】【WAV+CUE】
- 群星《Jazz-Ladies1-2爵士女伶1-2》HQCD/2CD[原抓WAV+CUE]
- 群星《美女私房歌》(黑胶)[WAV分轨]
- 郑源.2009《试音天碟》24BIT-96KHZ[WAV+CUE][1.2G]
- 飞利浦试音碟 《环球群星监听录》SACD香港版[WAV+CUE][1.1G]