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

理解Javascript_11_constructor實(shí)現(xiàn)原理

 更新時間:2010年10月18日 00:46:50   作者:  
在理解了'對象模型'后,我們就可以看一下constructor屬性是如何實(shí)現(xiàn)的.
constructor是什么

簡單的理解,constructor指的就是對象的構(gòu)造函數(shù)。請看如下示例:
復(fù)制代碼 代碼如下:

function Foo(){};
var foo = new Foo();
alert(foo.constructor);//Foo
alert(Foo.constructor);//Function
alert(Object.constructor);//Function
alert(Function.constructor);//Function

對于foo.constructor為Foo,我想應(yīng)該很好理解,因為foo的構(gòu)造函數(shù)為Foo。對于Foo、Object、Function的構(gòu)造函數(shù)為Function,我想也沒什么好爭議的。(因為Foo,Object,Function都是函數(shù)對象,又因為所有的函數(shù)對象都是Function這個函數(shù)對象構(gòu)造出來,所以它們的constructor為Function,詳細(xì)請參考《js_函數(shù)對象》)

Prototype與Constructor的關(guān)系

復(fù)制代碼 代碼如下:

function Dog(){}
alert(Dog === Dog.prototype.constructor);//true

在 JavaScript 中,每個函數(shù)都有名為“prototype”的屬性,用于引用原型對象。此原型對象又有名為“constructor”的屬性,它反過來引用函數(shù)本身。這是一種循環(huán)引用,如圖:

constructor屬性來自何方
我們來看一下Function構(gòu)造String的構(gòu)造過程:

注:Function構(gòu)造任何函數(shù)對象的過程都是一樣的,所以說不管是String,Boolean,Number等內(nèi)置對象,還是用戶自定義對象,其構(gòu)造過程都和上圖一樣。這里String只是一個代表而矣!
圖中可以看出constructor是Function在創(chuàng)建函數(shù)對象時產(chǎn)生的,也正如'prototype與constructor的關(guān)系'中講的那樣,constructor是函數(shù)對象prototype鏈中的一個屬性。即String=== String.prototype.constructor。

我還想用一段代碼來證明一下,理論是正確的:
復(fù)制代碼 代碼如下:

function Person(){}
var p = new Person();
alert(p.constructor);//Person
alert(Person.prototype.constructor);//Person
alert(Person.prototype.hasOwnProperty('constructor'));//true
alert(Person.prototype.isPrototypeOf(p));//true
alert(Object.prototype.isPrototypeOf(p));//true
alert(Person.prototype == Object.prototype);//false

到現(xiàn)在,你會發(fā)現(xiàn)這和前面《原型鏈的實(shí)現(xiàn)原理》中的默認(rèn)prototype指向Object.prototype有沖突,顯然當(dāng)時的理論不是很全面。

特別的Object
用心的讀者可能會提出這樣一問題,你這一套理論并不能適用于Object。因為以下的代碼和你上面的理論是沖突的:
復(fù)制代碼 代碼如下:

alert(Object.prototype.hasOwnProperty('constructor'));//true
alert(Object.prototype.hasOwnProperty('isPrototypeOf'));//true,如果按上面的理論,這里應(yīng)該返回false

真的是這樣嗎?不是!那我們來看一下特殊的Object是如何處理的:

你會發(fā)現(xiàn),這圖的原理和上面一張圖的原理是一樣的。這就能正確解釋Object.prototype.hasOwnProperty('isPrototypeOf')為true!

constructor探究
復(fù)制代碼 代碼如下:

function Animal(){}
function Person(){}
var person = new Person();
alert(person.constructor); //Person

根據(jù)上一節(jié)的內(nèi)容,你能正確的理解這段代碼的結(jié)果嗎?思考后,看一下其內(nèi)存表示:

這張圖明確有表明了Function構(gòu)造Animal和Person的過程。同時也顯示了實(shí)例person與Person的關(guān)系。

再深入一點(diǎn),代碼如下:
復(fù)制代碼 代碼如下:

function Animal(){}
function Person(){}
Person.prototype = new Animal();
var person = new Person();
alert(person.constructor); //Animal

這個時候,person的構(gòu)造函數(shù)成了Animal,怎么解釋?

注:圖中的虛線表示Person默認(rèn)的prototype指向(只作參考的作用)。但是我們將Person.prototype指向了new Animal。
此時,Person的prototype指向的是Animal的實(shí)例,所以person的constructor為Animal這個構(gòu)造函數(shù)。

結(jié)論:constructor的原理非常簡單,就是在對象的原型鏈上尋找constructor屬性。

注:如果你無法正確理解本文內(nèi)容,請回顧前面章節(jié)的內(nèi)容。

相關(guān)文章

最新評論