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)
作用:在陣列末端加入一個新的元素
實作方法:
Array.prototype.push = function(new_element){
this[this.length]=new_element;
return this.length;
# }
讓我們進一步來增強他,讓他可以一次增加多個元素!
實作方法:
Array.prototype.pushPro = function() {
var currentLength = this.length;##lt ; arguments.length; i++) {
this[currentLength + i] = arguments[i];
}
應該不難看懂吧?以此類推,你可以考慮如何透過增強Array.pop 來實現刪除任意位置,任意多個元素(具體程式碼就不再細說了)
作用:這實際上是String 類別的屬性,但是由於JavaScript 將全角、半角均視為一個字符,在一些實際運用中可能會造成一定的問題,現在我們透過prototype 來彌補這部不足。
實作方法:String.prototype.cnLength = function(){ var arr=this.match(/[^\x00- .length+(arr==null?0:arr.length);
試驗:alert("EaseWe空間Spaces".cnLength()) -> 顯示16
這裡用到了一些正規表示式的方法和全角字符的編碼原理,由於屬於另兩個比較大的類別,本文不加說明,請參考相關材料。
問題:用過vb 的應該都知道left函數,從字串左邊取n 個字符,但是不足是將全角、半角均視為是一個字符,造成在中英文混排的版面中不能截取等長的字符串
作用:從字符串左邊截取n 個字符,並支持全角半角字符的區分
if(!/\d+/.test(num))return(this);
0,num);
if(!mode) return str;
var n = str.Tlength() - str.length;
}
#
試驗:
alert("EaseWe空間Spaces".left(8)) -> 顯示EaseWe空間
alert("EaseWe空間Spaces".left(8,true)) -> 顯示EaseWease空
本方法用到了上面所提到的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
當然,也可以進一步擴充,得出回應的小時、分鐘,甚至是秒。
以上是js中prototype詳解的詳細內容。更多資訊請關注PHP中文網其他相關文章!