JavaScript组合模式学习要点

前端之家收集整理的这篇文章主要介绍了JavaScript组合模式学习要点前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。

组合模式:

将一组对象组合成树形结构,并统一对待组合对象和叶对象,忽略它们之间的不同(因为叶对象也可以也可以包含叶对象而成为组合对象),组合模式中的对象只能是一对多的关系,不能出现多对一。

基本单元:

一个组合对象包含多个叶对象。每个基本单元又可以是别的组合对象的叶对象类似文件夹与它里面的内容的关系网,一个文件夹或文件又可以是其它文件夹的内容,但一个文件夹或文件不能同时属于多个上级文件夹。

在JavaScript中实现组合模式时,要保证组合对象和叶对象拥有相同的接口方法,对同一组叶对象的操作必须具有一致性。

例子:

= 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组合模式。编程之家 jb51.cc 收集整理的教程希望能对你有所帮助,如果觉得编程之家不错,可分享给好友!感谢支持

原文链接:https://www.f2er.com/js/46282.html

猜你在找的JavaScript相关文章