网站大量收购独家精品文档,联系QQ:2885784924

Javascript模拟实现接口、多继承.doc

  1. 1、本文档共5页,可阅读全部内容。
  2. 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
  3. 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  4. 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
Javascript模拟实现接口、多继承

在Javascript模拟实现接口、多继承[模式] 2007-01-25 17:56 ? 在其他语言中比如C#、Java,接口方法在定义的时候都是未实现的,而我这里模拟的JS接口则是可以在定义的时候实现的。 定义接口: var IClassManager = { hasClass:function(className){}, addClass:function(className){} }; 定义菜单类: var Menu = function(options){ this._element = null; this.setXY = function(x,y){ if (x) this._element.style.left = x + px; if (y) this._element.style.top = y + px; } }; 定义菜单项类: var MenuItem = function(){ this.setText = function(){ }; } 其实菜单类和菜单项类都是基于HTMLElement的抽象,因此如果要让他们可以灵活的定义HTMLElement样式,那么都需要一组管理className的方法。因此Menu和MenuItem都需要实现IClassManager。辅助实现接口的方法: var extend = function(dest, source){ //实现接口 dest = self || {}; for (property in source) { if (!dest[property]) //如果dest也就是类没有同名的方法,则用接口默认实现方法。 dest[property] = dest[property]; } return dest; } extend(Menu.prototype, IClassManager); extend(MenuItem.prototype, IClassManager); 这样Menu和MenuItem都具有了Class的管理能力。 ? 通过extend,Menu和MenuItem可以实现任意的接口,并且同时实现多个接口。 在实现接口之前Menu和MenuItem还可以有一次继承的机会: Menu.prototype = new BaseClass(); //最简单的继承方式 然后再实现接口:extend(Menu.prototype, IClassManager); ? 这样就类似单根继承+多接口实现,很像C#或者Java吧 下面是完整的代码: ?(function(){ var Event = joyeach.util.Event; var extend = function(dest, source){ //实现接口 dest = self || {}; for (property in source) { if (!dest[property]) dest[property] = dest[property]; } return dest; } //Class Manager Interface var IClassManager= { hasClass:function(className){ var reg = new RegExp((?:^|\\s+) + className + (?:\\s+|$)); return reg.test(this._element[className]); }, addClass:function(className){ if (this.hasClass(el, className))? return;? this._element[className] = [this._element[className], className].join( ); }} /** * 菜单类 */ joyeach.controls.Menu = function(options){ this._element = null; this.setXY = function(x,y){ if (x) this._element.style.left = x + px; if (y) this._element.style.top = y + px; }; this.getXY = function(){ return [parseInt(this._element.style.left), parseInt(this._element.style.top)]; }; this.addItem = function(item){ this._element.appendChild(item._element); E

文档评论(0)

htfyzc + 关注
实名认证
内容提供者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档