prototype是一個用於擴充類的對象的方法的方法.
一.對於一個對象,要給它註冊一個方法,可以用三種方法.
1.o.m=string;;這種太麻煩,
2.在constructor(構造器)裡面將它註冊進去.占空間.
3.但是這種方法會佔用很大的記憶體和空間.於是有一種更好的方法.就是用Object的prototype方法將這些方法存在同一個地址,供所建立的對象
一起用.假設我們定義了一個建構函式Circle(),用來建立表示圓形的對象.因為這個類的原形對象是circle.prototype,所以我們可以
定義一個對所有circle
對象都有效常量,如circle.prototype.pi=3.1415926;circle.prototype.area=function()
{return this.pi*this.r*this.r;},然後當我們再建立對象時,就可以直接調用它的這些方法和屬性了.
二.執行個體屬性,執行個體方法,類屬性,類方法.
用prototype建立說明的方法屬於 執行個體方法.應該用對象名來調用 .
如circle.prototype.area = circle-area;
三.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;
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.Tlength = function(){
var arr=this.match(/[^\x00-\xff]/ig);
return this.length+(arr==null?0:arr.length);
}
實驗:alert("aa啦啦aa".Tlength()) -> 顯示 8
這裡用到了一些Regex的方法和全形字元的編碼原理,由於屬於另兩個比較大的類別,本文不加說明,請參考相關材料。
3、新功能的實現,深入 prototype:在實際編程中所用到的肯定不只是已有方法的增強,更多的實行的功能的要求,下面我就舉兩個用 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("aa啦啦aa".left(4)) -> 顯示 aa啦啦
alert("aa啦啦aa".left(4,true)) -> 顯示 aa啦
本方法用到了上面所提到的String.Tlength()方法,自訂方法之間也能組合出一些不錯的新方法呀!