JavaScript编写类的扩展方法.pdf

  1. 1、本文档共5页,可阅读全部内容。
  2. 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
  3. 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  4. 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 去扩展,当觉得类本身提供的方法和属性

文档评论(0)

l215322 + 关注
实名认证
内容提供者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档