javascript教程50:認識instanceof 與 原型鏈

來源:互聯網
上載者:User

標籤:sed   for   基於   .com   src   原型鏈   img   通過   eof   

1 instanceof:

1.1 普通使用下: 判斷一個對象是否是某個建構函式的執行個體:

文法 : 對象 instanceof 函數 是則返回true,不是則返回false.

console.log(obj instanceof Object);

 

1.2 進階用法:

判斷一個函數的原型對象,是否在執行個體對象的原型鏈上

1.3 案例如下:

var arr = [];console.log(arr instanceof Array); //trueconsole.log(arr instanceof Object);  //true

 

2 原型鏈

MDN文檔是這樣解釋的:

2.1 .JavaScript 常被描述為一種基於原型的語言 (prototype-based language)——每個對象擁有一個原型對象,對象以其原型為模板、從原型繼承方法和屬性。

其中:

1 對象 調用.prototype屬性,訪問到原型對象.可對其操作.

2 原型對象 調用.constructor屬性,訪問到對象.

3 解釋demo如下:

(下面舉例以建構函式Person作為文檔中的對象來解釋).

function Person(){ } Person.prototype.sayName = function(){   console.log(1); } var zs =  new Person(); zs.sayName();//1

 

4 為關係:

以父親(建構函式原型對象) 母親(建構函式) 兒子(執行個體對象zs)來解釋其間的關係.

 

釋義:

 

釋義1 var zs = new Person();

建構函式Person(母親)),創造了執行個體對象(兒子)zs.

釋義2 Person.prototype.sayName

Person通過 Person.prototype訪問到(父親)"原型對象",並添加了函數sayName.

釋義3 zs.sayName();//1

(兒子)zs可以訪問到,父母兩對象內的所有變數和方法.

釋義4 Person.prototype.constructor.prototype.sayName

(父親)"原型對象"通過.constructor,訪問到建構函式Person(母親).

2.2 . 原型對象也可能擁有原型,並從中繼承方法和屬性**,一層一層、以此類推**。

這種關係常被稱為原型鏈 (prototype chain),它解釋了為何一個對象會擁有定義在其他對象中的屬性和方法。

關係如所示:

 

 

解釋:

2.1 原型對象(父親)本身,也可能作為兒子被創造出來. 即:原型對象(父親)上面也有它的父親母親,去繼承他們的屬性方法去使用.

2.2 通過這一層層的關係,從**執行個體對象 ~ null **構成了一個原型鏈.

3 .原型鏈使用:

3.1 根據原型鏈特有的規則,我們通常在對象內添加公用屬性;原型對象內添加私人屬性.

4 對象尋找屬性的規則:

先在自己身上找屬性,如果有,就直接返回,如果沒有,就順著原型鏈往上找

 

javascript教程50:認識instanceof 與 原型鏈

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.