十年网站开发经验 + 多家企业客户 + 靠谱的建站团队
量身定制 + 运营维护+专业推广+无忧售后,网站问题一站解决
这篇文章主要讲解了如何使用javascript中的组合模式,内容清晰明了,对此有兴趣的小伙伴可以学习一下,相信大家阅读完之后会有帮助。
成都创新互联专注为客户提供全方位的互联网综合服务,包含不限于成都网站设计、做网站、武清网络推广、微信小程序、武清网络营销、武清企业策划、武清品牌公关、搜索引擎seo、人物专访、企业宣传片、企业代运营等,从售前售中售后,我们都将竭诚为您服务,您的肯定,是我们大的嘉奖;成都创新互联为所有大学生创业者提供武清建站搭建服务,24小时服务热线:18982081108,官方网址:www.cdcxhl.com介绍:组合模式又叫部分整体模式,用于把一组相似的对象当作一个单一的对象。组合模式依据树形结构来组合对象,用来表示部分以及整体层次
定义:组合多个对象形成树形结构以表示具有整体一部分关系的层次机构。组合模式对单个对象(即叶子对象)和组合对象(即容器对象)的使用具有一致性,组合模式又可以成为整体一部分模式。
它是一种对象结构型模式。
场景:我们对公司的人员架构进行一下打印,假设所有管理岗和开发岗的区别只有一个,是不是有下级员工。我们来实现下:
示例:
var LEADER = function(name,dept){ this._name = name || ''; //姓名 this._dept = dept || ''; //职位 this._subordinates = []; //下属 this.add = function(employee){ this._subordinates.push(employee); } this.remove = function(employee){ this._subordinates.splice(this._subordinates.indexOf(employee),1); } this.getSubordinates = function(){ return this._subordinates; } this.toString = function(){ console.log('姓名:'+this._name+',职位:'+this._dept) } } var JAVARD = function(name,dept){ this._name = name || ''; //姓名 this._dept = dept || ''; //职位 this.toString = function(){ console.log('姓名:'+this._name+',职位:'+this._dept) } } var FERD = function(name,dept){ this._name = name || ''; //姓名 this._dept = dept || ''; //职位 this.toString = function(){ console.log('姓名:'+this._name+',职位:'+this._dept) } } function addData(){ var CEO = new LEADER('spancer','CEO'); var CTO = new LEADER('zijian','CTO'); var MANAGER = new LEADER('jiang','LEADER'); var JAVA_LEADER = new LEADER('fei','JAVA_LEADER'); var FE_LEADER = new LEADER('risker','FE_LEADER'); var wh = new FERD('wanghui','FE'); var si = new FERD('si','FE'); var amy = new FERD('amy','FE'); var wei = new JAVARD('wei','JAVA'); var guo = new JAVARD('guo','JAVA'); var yuan = new JAVARD('yuan','JAVA'); CEO.add(CTO); CTO.add(MANAGER); MANAGER.add(JAVA_LEADER); MANAGER.add(FE_LEADER); FE_LEADER.add(wh); FE_LEADER.add(si); FE_LEADER.add(amy); JAVA_LEADER.add(wei); JAVA_LEADER.add(guo); JAVA_LEADER.add(yuan); return CEO; } var eachEmployee = function(employee){ for(var employ of employee.getSubordinates()){ employ.toString(); if(employ.getSubordinates && employ.getSubordinates().length > 0){ eachEmployee(employ); } } } var CEO = addData(); CEO.toString(); eachEmployee(CEO); // 姓名:spancer,职位:CEO // 姓名:zijian,职位:CTO // 姓名:jiang,职位:LEADER // 姓名:fei,职位:JAVA_LEADER // 姓名:wei,职位:JAVA // 姓名:guo,职位:JAVA // 姓名:yuan,职位:JAVA // 姓名:risker,职位:FE_LEADER // 姓名:wanghui,职位:FE // 姓名:si,职位:FE // 姓名:amy,职位:FE
另外有需要云服务器可以了解下创新互联scvps.cn,海内外云服务器15元起步,三天无理由+7*72小时售后在线,公司持有idc许可证,提供“云服务器、裸金属服务器、高防服务器、香港服务器、美国服务器、虚拟主机、免备案服务器”等云主机租用服务以及企业上云的综合解决方案,具有“安全稳定、简单易用、服务可用性高、性价比高”等特点与优势,专为企业上云打造定制,能够满足用户丰富、多元化的应用场景需求。