- 1、本文档共5页,可阅读全部内容。
- 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
JavaScript编写类的扩展方法
1 / 5
JavaScript 编写类的扩展方法
在 JavaScript 中可以使用类的 prototype 属性来扩展类的属性和方法,在实际开发当中,当 JavaScript 内置的那些类
所提供的动态方法和动态属性不满足我们实际开发时,我们就可以通过prototype属性给自定义类添加方法和属性或者扩展
原有的类中的方法和属性。
一、扩展 JavaScript 内置类,添加动态方法
语法格式:
类名.prototype.方法名 = function([param1],[param2],....[paramn]) {
.................
}
[param1],[param2],....[paramn]这些参数都是可选的
使用这种方式给类添加的扩展方法都是动态的,动态方法是针对类的实例对象的,所以调用必须要用对象.方法名的形
式去调用,不能用类名.方法名的形式去调用!
1.1、使用 prototype 属性扩展 String 类
String 类是 JavaScript 内置的一个类,但是这个 String 类没有 quote 方法,此时就可以使用 String 类的 prototype
属性去扩展 String 类了,为 String 类添加一个实例方法(动态方法),这样每一个 String 类对象就都有 quote 方法了,这就
达到了将 String 类扩展的效果,增强了 String 类的使用。
1 /*扩展为 String 类,为 String 类增加 quote(两边加字符)方法*/
2 String.prototype.quote = function(quotestr) {
3 if (!quotestr) {
4 quotestr = \;
5 }
6 return quotestr + this + quotestr;
7 };
测试 String 类新添加的 quote 方法
1 alert(abc.quote());
2 alert(abc.quote(|));
测试结果:
2 / 5
1.2、使用 prototype 扩展 Number 类
1 Number.prototype.add=function(n){
2 //哪个对象调用 this 所在的函数,那么 this 代表的就是哪个对象实例
3 return this+n;
4 }
测试 Number 类新添加的 add 方法
1 var i= new Number(10);//等价于 var i=10;
2 alert(i.Add(10).Add(30)的结果是:+i.Add(10).Add(30));
3 var b=40;
4 alert(b.Add(90)的结果是:+b.Add(90));
测试结果:
1.3、使用 prototype 扩展 Array 类
1 Array.prototype.findVal=function(val){
2 var index=-1;
3 //哪个对象调用 this 所在的函数,那么 this 代表的就是哪个对象实例
4 for(var i=0;ithis.length;i++){
3 / 5
5 if(val==this[i]){
6 index=i;
7 break;
8 }
9 }
10 return index;
11 }
测试 Array 类新添加的 findVal 方法
1 var arr = new Array();
2 arr[0]=孤傲苍狼;
3 arr[1]=白虎神皇;
4 arr[2]=灭世魔尊;
5 alert(arr.FindVal(\白虎神皇\)返回的索引是:+arr.FindVal(白虎神皇));
测试结果:
以上三个小例子就是使用类的 prototype 属性扩展了 String 类,Number 类,Array 类,分别给这三个类添加了本身不
存在的 quote,add,findVal 方法,JavaScript 所有的类都可以使用 prototype 去扩展,当觉得类本身提供的方法和属性
您可能关注的文档
- INTEGRATING ASYNCHRONOUS DIGITAL DESIGN AND TESTING INTO THE UNDERGRANDUATE COMPUTER ENGINEERING CUR.pdf
- Integrating general-purpose and corpus-based verb classification.pdf
- Integration of QoS Enabled Distributed Object Computing Middleware for Develovping Next-Generation D.pdf
- Integrationofspe_省略_peechrecognition_425.pdf
- Integrated QoE Assessment Mechanism in Wireless Ubiquitous networks.pdf
- Intel 4系列主板BIOS设置详解 中.pdf
- Integrative outburst prevention technique of high-pressure jet of abrasive drilling slotting.pdf
- Intel OPEN SOURCE COMPUTER VISION LIBRARY.pdf
- Inter-language reflection A conceptual model.pdf
- Intelligent Transportation Systems Telematics Safe and Fun Driving.pdf
文档评论(0)