DIV CSS 佈局教程網

 DIV+CSS佈局教程網 >> 網頁腳本 >> JavaScript入門知識 >> 關於JavaScript >> 淺入深講解prototype的具體使用方法教程
淺入深講解prototype的具體使用方法教程
編輯:關於JavaScript     

破洛洛文章簡介:但是在實際的編程過程中不知道有沒有感覺到現有方法的不足?prototype 方法應運而生!下面,將通過實例由淺入深講解 prototype 的具體使用方法.

prototype 是在 IE 4 及其以後版本引入的一個針對於某一類的對象的方法,而且特殊的地方便在於:它是一個給類的對象添加方法的方法!這一點可能聽起來會有點亂,別急,下面我便通過實例對這一特殊的方法作已下講解:
 
首先,我們要先了解一下類的概念,JavaScript 本身是一種面向對象的語言,它所涉及的元素根據其屬性的不同都依附於某一個特定的類。我們所常見的類包括:數組變量(Array)、邏輯變量(Boolean)、日期變量(Date)、結構變量(Function)、數值變量(Number)、對象變量(Object)、字符串變量(String) 等,而相關的類的方法,也是程序員經常用到的(在這裡要區分一下類的注意和屬性發方法),例如數組的push方法、日期的get系列方法、字符串的split方法等等,
 
但是在實際的編程過程中不知道有沒有感覺到現有方法的不足?prototype 方法應運而生!下面,將通過實例由淺入深講解 prototype 的具體使用方法:
 
1、最簡單的例子,了解 prototype:
 (1) Number.add(num):作用,數字相加
 實現方法:

01.Number.prototype.add = function(num){return(this+num);}


試驗:alert((3).add(15)) -> 顯示 18
 (2) Boolean.rev(): 作用,布爾變量取反
 實現方法:
 

01.Boolean.prototype.rev = function(){return(!this);}

 試驗:alert((true).rev()) -> 顯示 false
 是不是很簡單?這一節僅僅是告訴讀者又這麼一種方法,這種方法是這樣運用的。
 
2、已有方法的實現和增強,初識 prototype:
 (1) Array.push(new_element)
 作用:在數組末尾加入一個新的元素
 實現方法:
 

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


讓我們進一步來增強他,讓他可以一次增加多個元素!
 實現方法:
 

01.Array.prototype.pushPro = function() {
 
02.        var currentLength = this.length;
 
03.               for (var i = 0; i < arguments.length; i++) {
 
04.                      this[currentLength + i] = arguments[i];
 
05.              }
 
06.       return this.length;
 
07.
 
08.}


應該不難看懂吧?以此類推,你可以考慮一下如何通過增強 Array.pop 來實現刪除任意位置,任意多個元素(具體代碼就不再細說了)
 (2) String.length
 作用:這實際上是 String 類的一個屬性,但是由於 JavaScript 將全角、半角均視為是一個字符,在一些實際運用中可能會造成一定的問題,現在我們通過 prototype 來彌補這部不足。
 
實現方法:
 

01.String.prototype.cnLength = function(){
 
02.       var arr=this.match(/[^\x00-\xff]/ig);
 
03.       return this.length+(arr==null?0:arr.length);
 
04.}

 試驗:alert(“EaseWe空間Spaces”.cnLength()) -> 顯示 16
 這裡用到了一些正則表達式的方法和全角字符的編碼原理,由於屬於另兩個比較大的類別,本文不加說明,請參考相關材料。
 
3、新功能的實現,深入 prototype:在實際編程中所用到的肯定不只是已有方法的增強,更多的實行的功能的要求,下面我就舉兩個用 prototype 解決實際問題的例子:
 
(1) String.left()
 問題:用過 vb 的應該都知道left函數,從字符串左邊取 n 個字符,但是不足是將全角、半角均視為是一個字符,造成在中英文混排的版面中不能截取等長的字符串
 作用:從字符串左邊截取 n 個字符,並支持全角半角字符的區分
 
實現方法:
 

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

 試驗:
 alert(“EaseWe空間Spaces”.left(8)) -> 顯示 EaseWe空間
 alert(“EaseWe空間Spaces”.left(8,true)) -> 顯示 EaseWe空
 本方法用到了上面所提到的String.Tlength()方法,自定義方法之間也能組合出一些不錯的新方法呀!
 
(2) Date.DayDiff()
 作用:計算出兩個日期型變量的間隔時間(年、月、日、周)
 實現方法:
 

01.Date.prototype.DayDiff = function(cDate,mode){
 
02.try{
 
03.cDate.getYear();
 
04.}catch(e){
 
05.return(0);
 
06.}
 
07.var base =60*60*24*1000;
 
08.var result = Math.abs(this - cDate);
 
09.switch(mode){
 
10.case "y":
 
11.result/=base*365;
 
12.break;
 
13.case "m":
 
14.result/=base*365/12;
 
15.break;
 
16.case "w":
 
17.result/=base*7;
 
18.break;
 
19.default:
 
20.result/=base;
 
21.break;
 
22.}
 
23.return(Math.floor(result));
 
24.}

 試驗:alert((new Date()).DayDiff((new Date(2002,0,1)))) -> 顯示 329
 alert((new Date()).DayDiff((new Date(2002,0,1)),”m”)) -> 顯示 10
 當然,也可以進一步擴充,得出響應的小時、分鐘,甚至是秒。
 
(3) Number.fact()
 作用:某一數字的階乘
 實現方法:
 

01.Number.prototype.fact=function(){
 
02.var num = Math.floor(this);
 
03.if(num<0)return NaN;
 
04.if(num==0 || num==1)
 
05.return 1;
 
06.else
 
07.return (num*(num-1).fact());
 
08.}


試驗:alert((4).fact()) -> 顯示 24
 這個方法主要是說明了遞歸的方法在 prototype 方法中也是可行的!
 

XML學習教程| jQuery入門知識| AJAX入門| Dreamweaver教程| Fireworks入門知識| SEO技巧| SEO優化集錦|
Copyright © DIV+CSS佈局教程網 All Rights Reserved