閱讀638 返回首頁    go 阿裏雲 go 技術社區[雲棲]


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 方法中也是可行的。

 

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

最後更新:2017-04-02 22:16:20

  上一篇:go 移動互聯網一周(2012.2.6-2012.2.12)大事記
  下一篇:go mysql error handler 例