Javascript中的prototype-阿里云开发者社区

开发者社区> it徐胖子> 正文

Javascript中的prototype

简介:
+关注继续查看
 

prototype 是在IE4及其以后版本引入的一个针对于某一类的对象的方法,而且特殊的地方便在于:它可以给一个给类的对象添加方法。

 

首先,我们要先了解一下类的概念,JavaScript 本身是一种面向对象的语言,它所涉及的元素根据其属性的不同都依附于某一个特定的类。我们所常见的类包括:数组变量(Array)、逻辑变量 (Boolean)、日期变量(Date)、结构变量(Function)、数值变量(Number)、对象变量(Object)、字符串变量 (String) 等,而相关的类的方法,也是程序员经常用到的(在这里要区分一下类的注意和属性方法),例如数组的push方法、日期的get系列方法、字符串的 split方法等等,

  

但是在实际的编程过程中不知道有没有感觉到现有方法的不足?prototype 方法应运而生!下面,将通过实例由浅入深讲解 prototype 的具体使用方法:

 

 

1 最简单的例子,了解prototype:

① Number.add(num):作用,数字相加
实现方法:Number.prototype.add = function(num){return(this+num);}
试验:alert((3).add(15)) -> 显示 18


② Boolean.rev(): 作用,布尔变量取反
实现方法:Boolean.prototype.rev = function(){return(!this);}
试验:alert((true).rev()) -> 显示 false


2 已有方法的实现和增强,初识prototype:


(1) Array.push(new_element)
  

作用:在数组末尾加入一个新的元素

  Array.prototype.push = function(new_element){
              this[this.length]=new_element;
              return this.length;
        }


  让我们进一步来增强他,让他可以一次增加多个元素!

  Array.prototype.pushPro = function() {
              var currentLength = this.length;
              for (var i = 0; i < arguments.length; i++) {
                       this[currentLength + i] = arguments[i];
              }
             return this.length;
         }


  以此类推,你可以考虑一下如何通过增强 Array.pop 来实现删除任意位置,任意多个元素。

 


(2) String.length
  

作用:这实际上是 String 类的一个属性,但是由于 JavaScript 将全角、半角均视为是一个字符,在一些实际运用中可能会造成一定的问题,现在我们通过 prototype 来弥补这部不足。
  实现方法:
  String.prototype.cnLength = function(){
               var arr=this.match(/[^\x00-\xff]/ig);
               return this.length+(arr==null?0:arr.length);
        }
  试验:alert("EaseWe空间Spaces".cnLength()) -> 显示 16
  这里用到了一些正则表达式的方法和全角字符的编码原理,由于属于另两个比较大的类别,本文不加说明,请参考相关材料。


3 新功能的实现,深入prototype:

在实际编程中所用到的肯定不只是已有方法的增强,更多的实行的功能的要求,

(1) String.left()
  

问题:用过 vb 的应该都知道left函数,从字符串左边取n个字符,但是不足是将全角、半角均视为是一个字符,造成在中英文混

排的版面中不能截取等长的字符串


作用:从字符串左边截取 n 个字符,并支持全角半角字符的区分

  String.prototype.left = function(num,mode){
              if(!/\d+/.test(num))return(this);
              var str = this.substr(0,num);
              if(!mode) return str;
              var n = str.Tlength() - str.length;
              num = num - parseInt(n/2);
              return this.substr(0,num);
         }

alert("EaseWe空间Spaces".left(8)) -> 显示 EaseWe空间
alert("EaseWe空间Spaces".left(8,true)) -> 显示 EaseWe空

本方法用到了上面所提到的String.Tlength()方法,自定义方法之间也能组合出一些不错的新方法呀!

(2) Date.DayDiff()
  

作用:计算出两个日期型变量的间隔时间(年、月、日、周)

  Date.prototype.DayDiff = function(cDate,mode){
         try{
             cDate.getYear();
         }catch(e){
             return(0);
         }
         var base =60*60*24*1000;
         var result = Math.abs(this - cDate);
         switch(mode){
             case "y":
                 result/=base*365;
                 break;
             case "m":
                 result/=base*365/12;
                 break;
             case "w":
                 result/=base*7;
                 break;
             default:
                 result/=base;
                 break;
         }
         return(Math.floor(result));
     }
  

alert((new Date()).DayDiff((new Date(2002,0,1)))) -> 显示 329
alert((new Date()).DayDiff((new Date(2002,0,1)),"m")) -> 显示 10
  

当然,也可以进一步扩充,得出响应的小时、分钟,甚至是秒。


(3) Number.fact()
  

作用:某一数字的阶乘
  

         Number.prototype.fact=function(){
               var num = Math.floor(this);
               if(num<0)return NaN;
               if(num==0 || num==1)
                       return 1;
               else
                      return (num*(num-1).fact());
        }


alert((4).fact()) -> 显示 24
  

这个方法主要是说明了递归的方法在 prototype 方法中也是可行的。

 

原帖地址:http://user.qzone.qq.com/378394241/blog/1328772213

版权声明:本文内容由阿里云实名注册用户自发贡献,版权归原作者所有,阿里云开发者社区不拥有其著作权,亦不承担相应法律责任。具体规则请查看《阿里云开发者社区用户服务协议》和《阿里云开发者社区知识产权保护指引》。如果您发现本社区中有涉嫌抄袭的内容,填写侵权投诉表单进行举报,一经查实,本社区将立刻删除涉嫌侵权内容。

相关文章
阿里云服务器怎么设置密码?怎么停机?怎么重启服务器?
如果在创建实例时没有设置密码,或者密码丢失,您可以在控制台上重新设置实例的登录密码。本文仅描述如何在 ECS 管理控制台上修改实例登录密码。
9894 0
阿里云服务器如何登录?阿里云服务器的三种登录方法
购买阿里云ECS云服务器后如何登录?场景不同,大概有三种登录方式:
2956 0
阿里云服务器ECS远程登录用户名密码查询方法
阿里云服务器ECS远程连接登录输入用户名和密码,阿里云没有默认密码,如果购买时没设置需要先重置实例密码,Windows用户名是administrator,Linux账号是root,阿小云来详细说下阿里云服务器远程登录连接用户名和密码查询方法
11536 0
阿里云服务器端口号设置
阿里云服务器初级使用者可能面临的问题之一. 使用tomcat或者其他服务器软件设置端口号后,比如 一些不是默认的, mysql的 3306, mssql的1433,有时候打不开网页, 原因是没有在ecs安全组去设置这个端口号. 解决: 点击ecs下网络和安全下的安全组 在弹出的安全组中,如果没有就新建安全组,然后点击配置规则 最后如上图点击添加...或快速创建.   have fun!  将编程看作是一门艺术,而不单单是个技术。
10876 0
使用SSH远程登录阿里云ECS服务器
远程连接服务器以及配置环境
2484 0
如何设置阿里云服务器安全组?阿里云安全组规则详细解说
阿里云安全组设置详细图文教程(收藏起来) 阿里云服务器安全组设置规则分享,阿里云服务器安全组如何放行端口设置教程。阿里云会要求客户设置安全组,如果不设置,阿里云会指定默认的安全组。那么,这个安全组是什么呢?顾名思义,就是为了服务器安全设置的。安全组其实就是一个虚拟的防火墙,可以让用户从端口、IP的维度来筛选对应服务器的访问者,从而形成一个云上的安全域。
7445 0
阿里云ECS云服务器初始化设置教程方法
阿里云ECS云服务器初始化是指将云服务器系统恢复到最初状态的过程,阿里云的服务器初始化是通过更换系统盘来实现的,是免费的,阿里云百科网分享服务器初始化教程: 服务器初始化教程方法 本文的服务器初始化是指将ECS云服务器系统恢复到最初状态,服务器中的数据也会被清空,所以初始化之前一定要先备份好。
7272 0
阿里云服务器ECS登录用户名是什么?系统不同默认账号也不同
阿里云服务器Windows系统默认用户名administrator,Linux镜像服务器用户名root
4402 0
+关注
it徐胖子
IT徐胖子
733
文章
0
问答
文章排行榜
最热
最新
相关电子书
更多
《2021云上架构与运维峰会演讲合集》
立即下载
《零基础CSS入门教程》
立即下载
《零基础HTML入门教程》
立即下载