彩世界开奖app官网-彩世界平台官方网址(彩票平台)
做最好的网站
来自 彩世界平台官方网址 2019-11-28 05:57 的文章
当前位置: 彩世界开奖app官网 > 彩世界平台官方网址 > 正文

为JavaScript类型增加方法的实现代码_javascript技巧

javaScript的类型函数(如Number/String/Boolean/Array/Date/Obejct等)都是继承于 Function.prototype,所以给Function.prototype增加方法,同时也会影响到由它衍生的下层类型函数。如: 复制代码 代码如下: Function.prototype.addMethod=function{ if{ this[methodName]=func;//给类型增加方法,类似于类型的静态方法。func方法是赋于了类型而非实例。 } return this;//this 将绑定到方法的调用对象,返回this可以进行链式调用 } Array.addMethod{alert; //Array.testFun {[native code]} Object.addMethod{alert; //Object.testFun(); //function Object() {[native code]} Boolean.addMethod{alert; //Boolean.testFun(); //function Boolean() {[native code]} function CustomObject{ this.name=name || 'CustomObject'; this.value=value || 0; this.toString=function(){return '[name:' this.name ',value:' this.value ']'} } CustomObject.addMethod{alert; /* return: * function CustomObject { this.name = name || "CustomObject"; this.value = value || 0; this.toString = function () {return "[name:" this.name ",value:" this.value "]";}; } */ CustomObject.testFun(); 此时如果用实例来调用的话,则会报错。如: 复制代码 代码如下: var customObject=new CustomObject(); //定义一个CustomObject实例 customObject.testFun();//Error: temp.testFun is not a function 给实例增加方法 如果给类型实例增加方法,则应该把方法绑定到类型的prototype上。如 复制代码 代码如下: Function.prototype.addMethod=function{ if(!this.prototype[methodName]){ this.prototype[methodName]=func;//给原型增加方法,此方法会影响到该类型的实例上 } return this.prototype;//返回原型,此类型实例可以进行链形调用 } Object.addMethod{alert; //{return '[Empty Object]'}}).testFun(); //[Empty Object] Number.addMethod{alert.testFun(); //5 String.addMethod{alert; //'test'.testFun(); //'test' Boolean.addMethod{alert; //true.testFun(); //true Array.addMethod{alert; //; //a,b Date.addMethod{alert.testFun(); //Tue Dec 27 2011 11:20:58 GMT-0800 (Pacific Standard Time) function CustomObject{ this.name=name || 'CustomObject'; this.value=value || 0; this.toString=function(){return '[name:' this.name ',value:' this.value ']'} } CustomObject.addMethod{alert; var customObject=new CustomObject(); customObject.testFun(); //[name:CustomObject,value:0] 若此时用类型调用testFun,则会报错。如 复制代码 代码如下: Array.addMethod{alert; //Array.testFun(); //Error: Array.testFun is not a function CustomObject.addMethod{alert; CustomObject.testFun(); //Error: CustomObject.testFun is not a function

如: 复制代码 代码如下: Function.prototype.addMethod=function{ if(!this.prototype[methodName]){ this.prototype[methodName]=func;//给原型增加方法,此方法会影响到该类型的实例上 } return this.prototype;//返回原型,此类型实例可以进行链形调用 } function CustomObject{ this.name=name || 'CustomeObject'; this.value=value || 0; this.toString=function(){ return '[name:' this.name ',value:' this.value ']' } } CustomObject.addMethod{}) var obj=new CustomObject(); var info=''; for{ info =property " | "; } alert; // name | value | toString | testFun | 但此时for in 也把该对象所继承于prototype对象中的属性也遍历出来了。如果要剔除它所继承的属性,可以用hasOwnProperty语句。如 复制代码 代码如下: Function.prototype.addMethod=function{ if(!this.prototype[methodName]){ this.prototype[methodName]=func;//给原型增加方法,此方法会影响到该类型的实例上 } return this.prototype;//返回原型,此类型实例可以进行链形调用 } function CustomObject{ this.name=name || 'CustomeObject'; this.value=value || 0; this.toString=function(){ return '[name:' this.name ',value:' this.value ']' } } CustomObject.addMethod{}) var obj=new CustomObject(); var info=''; for{ if(!obj.hasOwnProperty continue; info =property " | "; } alert; // name | value | toString |

本文由彩世界开奖app官网发布于彩世界平台官方网址,转载请注明出处:为JavaScript类型增加方法的实现代码_javascript技巧

关键词: 脚本 代码 类型 之家