js重写方法的简单实现

时间:2021-05-26

如下所示:

Function.prototype.method = function(name, fn) { this.prototype[name] = fn;//this指的应该是Function.prototype对象 return this;//返回此对象,这个有助于像jq那样的级联操作};Number.method("interge",function(){});//Number是一个构造函数,所以拥有上面的method方法,所以最后返回了Number对象(构造函数),所以可以(-10/3).interge()待续。。//主要是调用父类的方法Obj.method("surper",function(name){ var that = this; var method = that[name]; return function(){ return method.apply(that,arguments);//如果这里面没有that的话,就不会有cat.getName(that(是一个对象)) } });//下面是一个应用var coolcat = function(spec){ var that = cat(spec);//个人感觉这里,这里的that可以有了cat就有“一些方法” var getName = that.surper("getName");//这里感觉应该是用新生成的对象来做,应该才是更好的。最好不用that. that.get_name= function(){ return "me"+getName()+"me"; } return that;}

上面的内容来自《javascript语言精粹》,真的很不错。

以上这篇js重写方法的简单实现就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持。

声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。

相关文章