JavaScript中構(gòu)造函數(shù)與原型鏈之間的關(guān)系詳解
在Javascript中不存在class的概念,它的class概念是通過構(gòu)造函數(shù)(constructor)與原型鏈(prototype)來實現(xiàn)。
1.構(gòu)造函數(shù)(constructor):創(chuàng)建對象時的初始化對象,總是與new 關(guān)鍵是一同出現(xiàn)。
構(gòu)造函數(shù)存在以下特點:
- 1、構(gòu)造函數(shù)內(nèi)的this 指向當(dāng)前實例對象。
- 2、使用new 關(guān)鍵字實例化當(dāng)前對象。
- 3、構(gòu)造函數(shù)首字母大寫,區(qū)分普通函數(shù)。
- 4、實例對象都可以繼承構(gòu)造函數(shù)中的屬性和方法。但是,同一個對象實例之間,無法共享屬性。
2.原型(prototype):是一個對象,實現(xiàn)對象的屬性繼承。javascript 中的對象通過 proto 來指向原型對象,可以通過Object.__proto__ 來訪問
3.構(gòu)造函數(shù)與與原型的聯(lián)系:
<script> function Demo(){ } var demo = new Demo() var data= demo.prototype = function(){ } console.log(demo.__proto__) console.log(data.constructor ) console.log(data.prototype.__proto__) console.log(demo.constructor.prototype) console.log(demo.constructor) 輸出: {constructor: ƒ}constructor: ƒ Demo()__proto__: Object ƒ Function() { [native code] } {constructor: ƒ, __defineGetter__: ƒ, __defineSetter__: ƒ, hasOwnProperty: ƒ, __lookupGetter__: ƒ, …} {constructor: ƒ} ƒ Demo(){ } </script>
從以上輸出結(jié)果可以看出:
構(gòu)造函數(shù)的 __proto__ 指向原型對象;
原型的constructor 指向構(gòu)造函數(shù)Function;
原型的 prototype.__proto__ 等于 Object.__proto__;
實例 的 constructor.prototype 指向原型;
實例的constructor 指向構(gòu)造函數(shù)
引用圖例:
![1460000018155881][1]
相關(guān)文章
appendChild() 或 insertBefore()使用與區(qū)別介紹
appendChild() 方法在節(jié)點的子節(jié)點列表末添加新的子節(jié)點。insertBefore() 方法在節(jié)點的子節(jié)點列表任意位置插入新的節(jié)點,下面為大家介紹下具體的使用,感興趣的朋友不要錯過2013-10-10JavaScript DOM 學(xué)習(xí)第二章 編輯文本
在這一章我會給出一個在CMS里非常有用的更新頁面的代碼。在任一段落點擊鼠標(biāo)你就可以修改了。完成以后點擊按鈕,修改的文本就顯示了。2010-02-02深入解析contentWindow, contentDocument
沒有永恒的技術(shù)只有需求,沒有好說的客戶只有無奈的開發(fā)者,如果iframe的出現(xiàn)是一個錯誤的話,iframe里邊在來一個iframe那是錯上加錯,神話沒有在遠(yuǎn)古的塵囂中消失,卻在懷具的今天不斷上演2013-07-07jquery中prop()方法和attr()方法的區(qū)別淺析
官方例舉的例子感覺和attr()差不多,也不知道有什么區(qū)別,既然有了prop()這個新方法,不可能沒用吧,那什么時候該用attr(),什么時候該用prop()呢2013-09-09document 和 document.all 分別什么時候用
document 和 document.all 分別什么時候用...2006-09-09