欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

JavaScript中的類(Class)詳細介紹

 更新時間:2014年12月30日 08:41:48   投稿:junjie  
這篇文章主要介紹了JavaScript中的類(Class)詳細介紹,本文講解了JavaScript中類的定義、JavaScript中的Constructor(構造函數)、類名等內容,需要的朋友可以參考下

在JavaScript中,可以使用類(Class)來實現面向對象編程(Object Oriented Programming)。不過,JavaScript中的類與Java中的有所不同,其相應的定義和使用也不一樣。

JavaScript中類的定義

在JavaScript中,所有從同一個原型對象(prototype)處衍生出來的對象組成了一個類;也就是說,JavaScript中的類是一個對象集合的概念,如果兩個對象它們的prototype相同,那么它們就屬于同一個類;JavaScript中的類甚至都不需要類名。以下面的代碼為例:

復制代碼 代碼如下:

var p = {x:42};
var a = Object.create(p);
var b = Object.create(p);
console.log(a === b);//false
console.log(Object.getPrototypeOf(a) === Object.getPrototypeOf(b));//true

在上述例子中,對象a和b擁有相同的原型對象(prototype) p,因此a和b屬于同一個類(雖然這個類都沒有類名),它們從原型對象p處繼承了值為42的屬性x。

從這個例子中可以看到,原型對象的作用就相當于模板,可以由之衍生/創(chuàng)建出多個對象,其地位與Java語言中的類代碼(Class code)相同,是JavaScript中類定義的核心。以下這個例子中的原型對象就呈現出更像類代碼的樣子:


復制代碼 代碼如下:

var p = {
 INCREMENT_BY : 1,
 increment : function(x){
  return x + this.INCREMENT_BY;
 }
}
var a = Object.create(p);
var b = Object.create(p);
console.log(a.increment(7));//8
console.log(b.increment(9));//10


上述例子中,原型對象p定義了一個值為1的property (INCREMENT_BY)和一個名為increment的函數;對象a和b從p這個模板處獲取了INCREMENT_BY和increment函數。當調用對象a或b的increment函數時,JavaScript會試圖獲取a或b的INCREMENT_BY值(this.INCREMENT_BY);由于INCREMENT_BY是從p中獲取的,因此其值都是1 — 從模板中獲取的,值都相同的變量,類似于Java中的靜態(tài)類變量(static variable),因此上面的例子中對INCREMENT_BY變量命名時使用了全大寫字符。

在上面的例子中,所有從模板p處創(chuàng)建出來的對象(屬于同一個類的這些對象),其屬性和行為都是一模一樣的。但實際上對于同一個類的不同對象,它們除了擁有類所定義的屬性/行為以外,往往具有一些自身所特有的屬性與行為。因此,如果需要將prototype這個模板當作類來使用的話,就必須對每一個從中衍生出來的對象進行一定的定制:


復制代碼 代碼如下:

var p = {
 INCREMENT_BY : 1,
 increment : function(x){
  return x + this.INCREMENT_BY + this.custom_increment_by;
 }
}
var a = Object.create(p);
var b = Object.create(p);
a.custom_increment_by = 0;
b.custom_increment_by = 1;
console.log(a.increment(7));//8
console.log(b.increment(9));//11


在這個例子中,從模板p處創(chuàng)建出來的對象a和b擁有一個彼此間值不一定相等的變量custom_increment_by,而它們的increment()函數這個行為的最終結果則與custom_increment_by的值相關。一般來說,對新建對象進行定制化的工作往往放在統(tǒng)一的函數中進行:


復制代碼 代碼如下:

var p = {
 INCREMENT_BY : 1,
 increment : function(x){
  return x + this.INCREMENT_BY + this.custom_increment_by;
 }
}
function getIncrementalClassObject(customIncrementByValue){
 var incrementalObj = Object.create(p);
 incrementalObj.custom_increment_by = customIncrementByValue;
 return incrementalObj;
}
var a = getIncrementalClassObject(0);
var b = getIncrementalClassObject(1);
console.log(a.increment(7));//8
console.log(b.increment(9));//11


如此,便通過原型對象p和getIncrementalClassObject()函數完成了一個類的定義:可以通過調用getIncrementalClassObject()函數來獲取原型對象都是p的對象,而在調用getIncrementalClassObject()函數過程中可以對這些新建對象進行一定的定制化。值得注意的是,此時這個已經定義了的類還沒有類名,為了方便描述,姑且稱之為Incremental。

回顧getIncrementalClassObject()函數中所做的工作,可以看到從Incremental這個類中創(chuàng)建新的對象所經歷的過程如下:

1.創(chuàng)建一個空對象,并將其原型對象定義為p。
2.根據不同的參數值,對這個新建的空對象進行定制。
3.返回已經定制完成的新對象。

在JavaScript中,可以通過使用Constructor(構造函數)來快速地完成類的定義以及新對象的創(chuàng)建。

JavaScript中的Constructor(構造函數)

從上述Incremental類這個例子中可以看到,定義新的類需要兩部分代碼:創(chuàng)建原型對象作為模板、創(chuàng)建自定義函數對新對象進行初始化;而從類中創(chuàng)建新的對象則經歷了三個過程:指定新對象的原型對象、定制/初始化新對象、返回這個新對象。在JavaScript中,這一切都可以通過Constructor(構造函數)來完成。

JavaScript中的Constructor是一個函數(function),承擔對新對象進行初始化的職責;而這個Constructor函數的prototype則作為模板用于創(chuàng)建新對象。仍以上述Incremental類為例,用Constructor來重寫代碼后是這樣的:


復制代碼 代碼如下:

function Incremental(customIncrementByValue){
  this.custom_increment_by = customIncrementByValue;
}
Incremental.prototype = {
  INCREMENT_BY : 1,
 increment : function(x){
  return x + this.INCREMENT_BY + this.custom_increment_by;
 }
}

var a = new Incremental(0);
var b = new Incremental(1);
console.log(a.increment(7));//8
console.log(b.increment(9));//11

通過new關鍵詞,使用Constructor函數來創(chuàng)建新對象這一過程,其實際上經歷了以下幾個階段:

創(chuàng)建一個新的空對象。

1.將這個對象的原型對象指向constructor函數的prototype屬性。
2.將這個對象作為this參數,執(zhí)行constructor函數。
3.這與之前的getIncrementalClassObject()函數中所做的工作是一樣的。

類名

在使用Constructor創(chuàng)建對象時,相應的對象也就有了“類名”,這可以從instanceof操作符的結果上得到驗證:

復制代碼 代碼如下:

console.log(a instanceof Incremental);//true
console.log(b instanceof Incremental);//true

不過,instanceof操作符并不判斷對象是否由Incremental這一構造函數所創(chuàng)建,instanceof操作符只判斷對象的原型對象是否為Incremental.prototype。當存在兩個prototype一樣的構造函數時,instanceof操作符將統(tǒng)一返回true,而不會區(qū)分用于創(chuàng)建對象的構造函數到底是哪個。
復制代碼 代碼如下:

function Incremental2(customIncrementByValue){
  this.custom_increment_by = customIncrementByValue + 3;
}
Incremental2.prototype = Incremental.prototype;
console.log(a instanceof Incremental2);//true

相關文章

  • JavaScript懶加載詳解

    JavaScript懶加載詳解

    這篇文章主要為大家詳細介紹了JS實現頁面數據懶加載,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2021-11-11
  • Three.js基礎部分學習

    Three.js基礎部分學習

    本文主要分享了一個案例,介紹了使用Three.js繪制旋轉立方體的方法與實現過程。具有一定的參考價值,下面跟著小編一起來看下吧
    2017-01-01
  • JS delegate與live淺析

    JS delegate與live淺析

    這篇文章主要介紹了JS delegate與live,有需要的朋友可以參考一下
    2013-12-12
  • bootstrapTable+ajax加載數據 refresh更新數據

    bootstrapTable+ajax加載數據 refresh更新數據

    這篇文章主要為大家詳細介紹了bootstrapTable+ajax加載數據,以及refresh更新數據,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2018-08-08
  • 基于JS實現發(fā)送短信驗證碼后的倒計時功能(無視頁面刷新,頁面關閉不進行倒計時功能)

    基于JS實現發(fā)送短信驗證碼后的倒計時功能(無視頁面刷新,頁面關閉不進行倒計時功能)

    這篇文章主要介紹了基于JS實現發(fā)送短信驗證碼后的倒計時功能(無視頁面刷新,頁面關閉不進行倒計時功能)的相關資料,非常不錯,具有參考借鑒價值,需要的朋友可以參考下
    2016-09-09
  • 將html頁面保存成圖片,圖片寫入pdf的實現方法(推薦)

    將html頁面保存成圖片,圖片寫入pdf的實現方法(推薦)

    下面小編就為大家?guī)硪黄獙tml頁面保存成圖片,圖片寫入pdf的實現方法(推薦)。小編覺得挺不錯的,現在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2016-09-09
  • 前端中的JS使用調試技巧

    前端中的JS使用調試技巧

    掌握各種js調試技巧,在前端開發(fā)中降低開發(fā)成本,起到事半功倍的效果。譬如,快速定位問題、降低故障概率、幫助分析邏輯錯誤等等。這篇文章主要介紹了前端中的JS使用調試技巧,需要的朋友可以參考下
    2022-12-12
  • JavaScript必看的10道面試題總結(推薦)

    JavaScript必看的10道面試題總結(推薦)

    JavaScript 已經成為全棧開發(fā)技能的基石,在全棧開發(fā)面試中都會不可避免地涉及到與 JavaScript 有關的問題。這篇文章主要給大家介紹了關于JavaScript必看的10道面試題,需要的朋友可以參考下
    2021-05-05
  • 一文讀懂TS?中聯(lián)合類型和交叉類型各自的含義

    一文讀懂TS?中聯(lián)合類型和交叉類型各自的含義

    聯(lián)合類型在?TypeScript?中相當流行,你可能已經用過很多次了。交叉類型稍微不那么常見,它們似乎引起更多的困惑,這篇文章主要介紹了一文讀懂TS?中聯(lián)合類型和交叉類型的含義,需要的朋友可以參考下
    2022-12-12
  • uniapp中實現App自動檢測版本升級的示例代碼

    uniapp中實現App自動檢測版本升級的示例代碼

    本文主要介紹了uniapp中實現App自動檢測版本升級的示例代碼,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2023-01-01

最新評論