如下所示:
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重寫方法的簡單實現就是小編分享給大家的全部內容了,希望能給大家一個參考,也希望大家多多支持武林網。
新聞熱點
疑難解答