首頁  >  文章  >  web前端  >  淺析用prototype定義自己的方法_基礎知識

淺析用prototype定義自己的方法_基礎知識

WBOY
WBOY原創
2016-05-16 17:15:32953瀏覽

prototype 是在 IE 4 及其以後版本引入的一個針對於某一類的對象的方法,而且特殊的地方便在於:它是一個給類的對象添加方法的方法!這一點可能聽起來會有點亂,別急,下面我便透過實例對這特殊的方法作已下講解:

首先,我們要先了解類別的概念,JavaScript 本身就是一種物件導向的語言,它所涉及的元素根據其屬性的不同都依附於某一個特定的類別。我們常見的類別包括:陣列變數(Array)、邏輯變數(Boolean)、日期變數(Date)、結構變數(Function)、數值變數(Number)、物件變數(Object)、字串變數(String) 等,而相關的類別的方法,也是程式設計師常用的(這裡要區分一下類別的注意和屬性發方法),例如數組的push方法、日期的get系列方法、字串的split方法等等,

但是在實際的程式設計過程中不知道有沒有感覺到現有方法的不足? prototype 方法應運而生!下面,將透過實例由淺入深講解 prototype 的具體使用方法:

1、最簡單的例子,了解 prototype:

(1) Number.add(num):作用,數字相加
實作方法:Number.prototype.add = function(num){return(this num);}
試驗:alert((3).add(15)) -> 顯示18


(2) Boolean.rev(): 作用,布林變數取反
實作方法:Boolean.prototype.rev = function(){return(!this);}
試驗:alert((true).rev()) -> 顯示false

是不是很簡單?這一節只是告訴讀者又這麼一種方法,這種方法是這樣運用的。


2、已有方法的實現和增強,初識 prototype:

(1) Array.push(new_element)
作用:在陣列結束時加入一個新的元素

實作方法:

複製程式碼 程式碼如下:


程式碼如下:


程式碼如下:

程式碼如下:        this[this.length]=new_element;       ,讓他可以一次增加多個元素!

複製程式碼


程式碼如下:



程式碼如下:

程式碼如下:


程式碼如下:        var currentLength = this.length;

         this[currentLength i] = arguments[ i];        }
        return this.length;
    }

    }應該不難看吧?以此類推,你可以考慮如何透過增強 Array.pop 來實現刪除任意位置,任意多個元素(具體程式碼就不再細說了)
(2) String.length

作用:這實際上是String 類別的一個屬性,但是由於JavaScript 將全角、半角均視為是一個字符,在一些實際運用中可能會造成一定的問題,現在我們透過prototype 來彌補這部不足。


實作方法:
複製程式碼 程式碼如下: 程式碼如下: 程式碼如下: 程式碼如下:        var arr=this.match(/[^x00-xff]/ig);     . ;    }
試驗:alert("aa啦啦aa".Tlength()) -> 顯示 8

這裡用到了一些正規表示式的方法和全角字符的編碼原理,由於屬於另兩個比較大的類別,本文不加說明,請參考相關材料。

3、新功能的實現,深入prototype:在實際編程中所用到的肯定不只是已有方法的增強,更多的實行的功能的要求,下面我就舉兩個用prototype 解決實際問題的例子:

(1) String.left()
問題:用過vb 的應該都知道left函數,從字串左邊取n 個字符,但是不足是將全角、半角均視為是一個字符,造成在中英文混排的版面中不能截取等長的字符串

作用:從字串左邊截取 n 個字符,並支援全角半角字符的區分

實作方法:

複製程式碼 程式碼如下:


程式碼如下:



程式碼如下:


程式碼如下:        if(!/d /.test(num))return(this);
      >        if(!mode) return str;        var n = str.Tlength() - str.length;

    return this.substr(0,num );

    }


試驗:alert("aa啦啦aa".left(4)) -> 顯示aa啦啦
      alert("aa啦啦aa".left
      alert("aa啦啦aa".left (4,true)) -> 顯示aa啦
本方法用到了上面所提到的String.Tlength()方法,自訂方法之間也能組合出一些不錯的新方法呀!




複製程式碼


程式碼如下:


Date.prototype.DayDiff = func>

Date.prototype。 ,mode){
        try{
            cDate.getYear();        }
        var base =60*60*24 *1000;
        var result = Math.abs(this - cDate);
        switch(mode){
       switch(              result/=base*365;
               ,;
            case "m":
                result/=base*365/12;
                break;
            case "w":
                result/=base*7;
                break;
default:
                result/=base;
              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
當然,也可以進一步擴充,得出回應的小時、分鐘,甚至是秒。

複製程式碼 程式碼如下:

Number.prototype.fact=function(){
        var num = Math.floor(this);
    || num==1)
            return 1;
        else
    🎜>

試驗: alert((4).fact()) -> 顯示24
這個方法主要是說明了遞歸的方法在prototype 方法中也是可行的!
陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn