js重写方法

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语言精粹》,真的很不错



评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值