js重写方法
Function.prototype.method = function(name, fn) {
this.prototype[name] = fn;//this指的应该是Function.prototype对象
return this;//返回此对象,这个有助于像jq那样的级联操作
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语言精粹》,真的很不错
声明:该文观点仅代表作者本人,牛骨文系教育信息发布平台,牛骨文仅提供信息存储空间服务。
- 上一篇: Foundation-NSString前后缀检查
- 下一篇: 【OpenCV】访问图像中每个像素的值