国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 開發 > JS > 正文

JS利用prototype給類添加方法操作詳解

2024-05-06 16:52:33
字體:
來源:轉載
供稿:網友

本文實例講述了JS利用prototype給類添加方法操作。分享給大家供大家參考,具體如下:

1.如何定義一個簡單的類?

以下是一個沒有任何屬性和方法的類的定義:

function MyClass(){};

你可能會想,這不就是個簡單的函數聲明?沒錯,這個函數就是一個類的定義的實現。如何使用這個類呢?看下面的代碼:

var cls1 = new MyClass();

這樣,利用new就可以生成MyClass的一個實例了。所以在js中可以說函數就是類,類就是函數。

2.給類增加屬性和方法

function MyClass(name,age){  this.name = name;  this.age = age;}var cls1 = new MyClass("lily",18);alert(cls1.name);

從上面的代碼可以看出,在函數內使用this就能給函數本身增加屬性值。而在上面的代碼中就給myClass函數增加了name和age屬性。

同樣,還可以利用this給這個類增加一個 toString 方法,代碼如下:

function MyClass(name,age){  this.name = name;  this.age = age;  this.toString() = function(){    alert(this.name +":"+ this.age);  };}var cls1 = new MyClass("liming",10);cls1.toString();

我們已經成功的給MyClass增加了toString方法。另外也可以用以下代碼來添加方法:

function MyClass(name,age){  this.name = name;  this.age = age;}var cls1 = new MyClass("liming",10);cls1.toString() = function(){            alert(this.name +":"+ this.age);          };cls1.toString(); // [liming:10]var cls2 = new MyClass("zhang",10);cls2.toString(); //報錯

雖然這樣也能給這個類添加一個方法,但這種方式只是給cls1這個實例增加了方法,并未給MyClass本身增加方法。

cls2并不存在toString方法。

3.引出prototype

從上面我們已經知道要給MyClss類的本身增加方法,需要講方法定義在MyClass這個函數內部,這樣的話,每聲明一個新的實例,就會將MyClass本身復制一遍,這顯然不是最優的做法。

既然不能將一個類(函數)所包含的方法都定義在函數的內部,那么,如何來給一個類添加方法呢?這就需要用到函數的prototype屬性了。

每一個函數都會包含一個prototype屬性,這個屬性指向了一個prototype對象,我們可以指定函數對應的prototype對象。如果不指定,則函數的prototype屬性將指向一個默認的prototype對象,并且次默認的prototype對象的constructor屬性又會指向該函數。

當用構造函數創建一個新的對象時,新的對象會獲取構造函數的prototype屬性所指向的prototype對象的所有屬性和方法,這樣一來,構造函數對應的prototype對象所做的任何操作都會反映到它所生成的對象上,所有的這些對象將共享與構造函數對應的prototype對象的屬性和方法。

雖然新創建的對象可以使用它的構造函數所指向的prototype對象的屬性和方法,但不能像構造函數那樣直接調用prototype對象(對象沒有prototype屬性)。

簡而言之,就是如果我們使用函數的prototype對象來給函數添加方法,那么在創建一個新的對象的時候,并不會復制這個函數的所有方法,而是指向了這函數的所有方法。

具體看下面的代碼:

function MyClass(name,age){  this.name = name;  this.age = age;}MyClass.prototype.toString = function(){  //}var cls1 = new MyClass("liming",10);cls1.toString(); //var cls2 = new MyClass("zhang",10);cls2.toString();

如果要加入多個方法,也可以使用下面的方式:

function MyClass(name,age){  this.name = name;  this.age = age;}MyClass.prototype = {  toString:function(){    //  },  sayHellow:function(){    //  }};

這就是js中給類添加方法的實現,它是利用prototype來實現封裝的。

希望本文所述對大家JavaScript程序設計有所幫助。


注:相關教程知識閱讀請移步到JavaScript/Ajax教程頻道。
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 方正县| 石棉县| 湘潭县| 肇东市| 略阳县| 台东市| 娄烦县| 商洛市| 织金县| 积石山| 静安区| 石河子市| 红原县| 太仓市| 土默特左旗| 九龙县| 潜江市| 连平县| 梅河口市| 襄汾县| 紫阳县| 新绛县| 革吉县| 旺苍县| 石景山区| 金湖县| 庆安县| 齐齐哈尔市| 土默特左旗| 通榆县| 克什克腾旗| 鞍山市| 高邮市| 彭水| 虹口区| 汕头市| 宝坻区| 离岛区| 巨野县| 儋州市| 澄城县|