摘要:原文鏈接關(guān)于的原型和原型鏈,看我就夠了一參考鏈接闖關(guān)記之原型及原型鏈之原型與原型鏈一篇文章帶你理解原型和原型鏈徹底理解原型鏈一的默認(rèn)指向圖解和的三角關(guān)系原型和原型鏈三張圖搞懂的原型對象與原型鏈
溫故 創(chuàng)建對象的三種方式
通過對象直接量
通過new創(chuàng)建對象
通過Object.create()
js中對象分為兩種函數(shù)對象
普通對象
仔細(xì)觀察如下代碼
function Foo(name) { this.name = name; } var foo = new Foo("陌上寒"); console.log(foo)// Foo{name: "陌上寒"} //--------------- var foo1 = {name:""陌上寒""} //等價于 var foo1 = new Object() foo1.name = "陌上寒"
綜合以上,得出結(jié)論==>普通對象都是通過函數(shù)創(chuàng)建的
prototype每一個函數(shù)對象都有一個prototype屬性,但是普通對象是沒有的;
遺留問題昨天留下了一些知識點,今天重點討論
constructor
_proto_
知新 constructor構(gòu)造函數(shù)我們昨天說創(chuàng)建對象的三種方式,第二種是通過new創(chuàng)建對象,
var obj = new Object()//創(chuàng)建一個空對象等同于 var obj = {} console.log(obj.constructor===Object)//true
Object就是一個構(gòu)造函數(shù),是js內(nèi)置的構(gòu)造函數(shù),上面的例子中Object就是obj的構(gòu)造函數(shù),這個例子似乎不太明顯,我們繼續(xù)看
function Foo(name){ this.name = name } var foo = new Foo("陌上寒") console.log(foo.constructor===Foo)//true
我們自定義了一個構(gòu)造函數(shù)Foo,Foo是foo的構(gòu)造函數(shù),foo的構(gòu)造函數(shù)就是Foo
構(gòu)造函數(shù)與其他函數(shù)的唯一區(qū)別,就在于調(diào)用它們的方式不同。不過,構(gòu)造函數(shù)畢竟也是函數(shù),不存在定義構(gòu)造函數(shù)的特殊語法。任何函數(shù),只要通過 new 操作符來調(diào)用,那它就可以作為構(gòu)造函數(shù);而任何函數(shù),如果不通過 new 操作符來調(diào)用,那它跟普通函數(shù)也不會有什么兩樣。
構(gòu)造函數(shù)在創(chuàng)建時有一個約定,如果是構(gòu)造函數(shù),那么首字母要大寫,普通函數(shù)首字母小寫
constructor和我們昨天討論的prototype有什么聯(lián)系嗎?
觀察如下代碼的輸出
function Foo(name) { this.name = name; } var foo = new Foo("陌上寒"); console.log(Foo.prototype)
通過昨天的討論我們得知只有函數(shù)對象才存在prototype
輸出
Foo.prototype是Foo的原型對象
繼續(xù)觀察
function Foo(name) { this.name = name; } var foo = new Foo("陌上寒"); console.log(Foo.prototype.constructor===Foo)//true
在默認(rèn)情況下,所有原型對象都會自動獲得一個 constructor(構(gòu)造函數(shù))屬性,這個屬性包含一個指向 prototype 屬性所在函數(shù)的指針。就拿前面的例子來說,F(xiàn)oo.prototype.constructor 指向 Foo。
我們得出以下結(jié)論
原型對象中的constructor屬性,指向該原型對象對應(yīng)的構(gòu)造函數(shù)
也就是說上面的例子,F(xiàn)oo的原型對象是Foo.prototype,原型對象(Foo.prototype)中有一個constructor屬性,這個constructor屬性指向原型對象(Foo.prototype)對應(yīng)的構(gòu)造函數(shù)Foo,用一行代碼概括
console.log(Foo.prototype.constructor===Foo)//true
以上就是constructor和prototype的關(guān)系
我們注意到原型對象(Foo.prototype)中還存在一個屬性__proto__,這又是什么?它和prototype,constructor又有什么關(guān)聯(lián)呢?
那么__proto__是什么?每個對象都會在其內(nèi)部初始化一個屬性,就是__proto__。
Firefox、Safari 和 Chrome 的每個對象上都有這個屬性 ,而在其他瀏覽器中是完全不可見的(為了確保瀏覽器兼容性問題,不要直接使用 _proto_ 屬性,此處只為演示)。我們繼續(xù)看代碼
var arr = new Array() console.log(arr.__proto__===Array.prototype);//true var str = new String() console.log(str.__proto__===String.prototype);//true var Fun = new Function() console.log(Fun.__proto__===Function.prototype);//true var bool = new Boolean console.log(bool.__proto__===Boolean.prototype);//true var obj = new Object() console.log(obj.__proto__===Object.prototype);//true function MyFun() { console.log("我是陌上寒"); } var myfoo = new MyFun() console.log(myfoo.__proto__===MyFun.prototype);//true
再重復(fù)一次:Array,String,F(xiàn)unction,Boolean,Object都是js內(nèi)置的構(gòu)造函數(shù),MyFun是自定義的構(gòu)造函數(shù)
只有函數(shù)對象才存在prototype
所有對象(除了Object.prototype)都存在_proto_
剛才我們討論過,普通對象都是通過函數(shù)創(chuàng)建的
根據(jù)以上我們得出結(jié)論:
普通對象__proto__指向當(dāng)前函數(shù)對象的原型,
你可能發(fā)現(xiàn)了,有一個矛盾的地方,所有對象都存在__proto__,只有普通對象的__proto__指向當(dāng)前函數(shù)對象的原型,那函數(shù)對象的__proto__指向哪里呢?繼續(xù)看代碼
function MyFun() { console.log("我是陌上寒"); } console.log(Boolean.__proto__);//? () { [native code] } console.log(Function.__proto__);//? () { [native code] } console.log(String.__proto__);//? () { [native code] } console.log(Array.__proto__);//? () { [native code] } console.log(Object.__proto__);//? () { [native code] } console.log(MyFun.__proto__);//? () { [native code] }
函數(shù)對象的__proto__輸出的都是? () { [native code] }
函數(shù)內(nèi)部是[native code],也就是系統(tǒng)編譯好的二進(jìn)制代碼函數(shù),我們不對此做研究
上面說到,所有對象都有__proto__,原型對象也是對象,
我們得出結(jié)論
原型對象也存在_proto_
結(jié)合以上我門又一次得出結(jié)論
原型對象的__proto__指向當(dāng)前函數(shù)對象的原型,
還是繼續(xù)看代碼,便于理解*
console.log("陌上寒".__proto__===String.prototype);//true console.log(String.prototype.__proto__===Object.prototype);//true //等量代換,得出一下結(jié)論 console.log("陌上寒".__proto__.__proto__===Object.prototype);//true //自此形成了一條鏈,===>原型鏈
解釋一下如上代碼,
"陌上寒"是字符串類型,"陌上寒"的構(gòu)造函數(shù)是String(), 所以"陌上寒"的__proto__指向String的原型
String()是js的內(nèi)置構(gòu)造函數(shù),繼承自O(shè)bject,也就是說Object是頂端,是原型鏈的頂端,既然是頂端,所以:
console.log(Object.prototype.__proto__)//null
Object的原型對象是不存在__proto__的
總結(jié)所有對象(不包括Object.prototype)有__proto__屬性,函數(shù)對象有prototype屬性;
對象由函數(shù)生成;
生成對象時,對象的__proto__屬性指向當(dāng)前函數(shù)的prototype屬性。
Object.prototyp處于原型鏈的頂端,不存在原型,不繼承任何屬性,其他原型對象都是普通對象,普通對象都具有原型,所有的內(nèi)置構(gòu)造函數(shù)(以及大部分自定義構(gòu)造函數(shù))都具有一個繼承自O(shè)bject.prototype的原型,例如Date.prototype的 屬性繼承自O(shè)bject.prototype,因此有new Date()創(chuàng)建的Date對象的屬性同時繼承自Date.prototype和Object.prototype,這一系列的原型對象就是所謂的原型鏈。
原文鏈接
關(guān)于javascript的原型和原型鏈,看我就夠了(一)
參考鏈接
《JavaScript 闖關(guān)記》之原型及原型鏈
JavaScript之原型與原型鏈
一篇文章帶你理解原型和原型鏈
徹底理解JavaScript原型鏈(一)—__proto__的默認(rèn)指向
圖解prototype、proto和constructor的三角關(guān)系
Object.prototype 原型和原型鏈
三張圖搞懂JavaScript的原型對象與原型鏈
文章版權(quán)歸作者所有,未經(jīng)允許請勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。
轉(zhuǎn)載請注明本文地址:http://systransis.cn/yun/98978.html
摘要:要用作原型的對象。函數(shù)對象可以創(chuàng)建普通對象,這個我們上面講過了回顧一下這是一個自定義構(gòu)造函數(shù)普通對象沒法創(chuàng)建函數(shù)對象,凡是通過創(chuàng)建的對象都是函數(shù)對象,其他都是普通對象通常通過創(chuàng)建,可以通過來判斷。 關(guān)于js的原型和原型鏈,有人覺得這是很頭疼的一塊知識點,其實不然,它很基礎(chǔ),不信,往下看要了解原型和原型鏈,我們得先從對象說起 創(chuàng)建對象 創(chuàng)建對象的三種方式: 對象直接量 通過對象直接量創(chuàng)建...
摘要:對于中的引用類型而言,是保存著它們所有實例方法的真正所在。高級程序設(shè)計構(gòu)造函數(shù)陌上寒原型對象有一個屬性,指向該原型對象對應(yīng)的構(gòu)造函數(shù)為什么有屬性那是因為是的實例。 溫故 我們先回顧一下前兩天討論的內(nèi)容 創(chuàng)建對象的三種方式 通過對象直接量 通過new創(chuàng)建對象 通過Object.create() js中對象分為兩種 函數(shù)對象 普通對象 原型對象prototype 每一個函數(shù)對象都...
摘要:基本概念方法會返回一個布爾值,指示對象自身屬性中非繼承屬性是否具有指定的屬性,如果具有帶指定名稱的屬性,則方法返回,否則返回。此方法不會檢查對象原型鏈中的屬性該屬性必須是對象本身的一個成員。使用語法參數(shù),必需。 hasOwnProperty基本概念 hasOwnProperty() 方法會返回一個布爾值,指示對象自身屬性中(非繼承屬性)是否具有指定的屬性,如果 object 具有帶指定...
摘要:也就是說,所有的函數(shù)和構(gòu)造函數(shù)都是由生成,包括本身。如果只考慮構(gòu)造函數(shù)和及其關(guān)聯(lián)的原型對象,在不解決懸念的情況下,圖形是這樣的可以看到,每一個構(gòu)造函數(shù)和它關(guān)聯(lián)的原型對象構(gòu)成一個環(huán),而且每一個構(gòu)造函數(shù)的屬性無所指。 前言 JavaScript 是我接觸到的第二門編程語言,第一門是 C 語言。然后才是 C++、Java 還有其它一些什么。所以我對 JavaScript 是非常有感情的,畢...
閱讀 3220·2021-11-19 09:40
閱讀 3013·2021-09-09 09:32
閱讀 802·2021-09-02 09:55
閱讀 1403·2019-08-26 13:23
閱讀 2421·2019-08-26 11:46
閱讀 1240·2019-08-26 10:19
閱讀 2070·2019-08-23 16:53
閱讀 1081·2019-08-23 12:44