成人国产在线小视频_日韩寡妇人妻调教在线播放_色成人www永久在线观看_2018国产精品久久_亚洲欧美高清在线30p_亚洲少妇综合一区_黄色在线播放国产_亚洲另类技巧小说校园_国产主播xx日韩_a级毛片在线免费

資訊專欄INFORMATION COLUMN

學(xué)習(xí)JavaScript的原型筆記

Nino / 2030人閱讀

摘要:通過(guò)同一個(gè)構(gòu)造函數(shù)實(shí)例化的多個(gè)對(duì)象具有相同的原型對(duì)象。構(gòu)造函數(shù)的原型對(duì)象是實(shí)例對(duì)象通過(guò)屬性也指向原型對(duì)象。如果把函數(shù)當(dāng)成實(shí)例對(duì)象的話,其構(gòu)造函數(shù)是,其原型對(duì)象是類似地,函數(shù)的構(gòu)造函數(shù)也是,其原型對(duì)象是。

JavaScript的原型(prototype、__proto__、constructor)
構(gòu)造函數(shù):function Foo() {};
實(shí)例對(duì)象: let f1 = new Foo;
let o1 = new Foo;

(全文的proto指兩個(gè)下劃線中間proto)

一般函數(shù)都有prototype屬性,除了window.MathFunction.prototype.bind()(該屬性指向原型)等

一般對(duì)象都有proto屬性,除了Object.create(null)等,該屬性指向了創(chuàng)建該對(duì)象的構(gòu)造函數(shù)的原型。其實(shí)這個(gè)屬性指向了[[prototype],但是[[prototype]]是內(nèi)部屬性,我們并不能訪問(wèn)到,所有采用proto來(lái)訪問(wèn)??傊?,對(duì)象可以通過(guò)proto來(lái)訪問(wèn)不屬于該對(duì)象的屬性,proto將對(duì)象連接起來(lái)組成了原型鏈。

概念:

構(gòu)造函數(shù):用來(lái)初始化新創(chuàng)建的對(duì)象的函數(shù)是構(gòu)造函數(shù)。上例中,Foo()函數(shù)是構(gòu)造函數(shù)。

實(shí)例對(duì)象:通過(guò)構(gòu)造函數(shù)的new操作創(chuàng)建的對(duì)象是實(shí)例對(duì)象。(可以用一個(gè)構(gòu)造函數(shù),構(gòu)造多個(gè)實(shí)例對(duì)象)

function Foo(){};
var f1 = new Foo;
var f2 = new Foo;
console.log(f1 === f2);//false

3.原型對(duì)象及prototype:構(gòu)造函數(shù)有一個(gè)prototype屬性,指向?qū)?yīng)實(shí)例對(duì)象的原型對(duì)象。通過(guò)同一個(gè)構(gòu)造函數(shù)實(shí)例化的多個(gè)對(duì)象具有相同的原型對(duì)象。這個(gè)屬性可以用來(lái)實(shí)現(xiàn)繼承。

function Foo(){};
Foo.prototype.a = 1;
var f1 = new Foo;
var f2 = new Foo;

console.log(Foo.prototype.a);//1
console.log(f1.a);//1
console.log(f2.a);//1

4.constructor:原型對(duì)象有一個(gè)constructor屬性,指向該原型對(duì)象對(duì)應(yīng)的構(gòu)造函數(shù)。由于實(shí)例對(duì)象可以繼承原型對(duì)象的屬性,所以實(shí)例對(duì)象也擁有constructor屬性,同樣指向原型對(duì)象對(duì)應(yīng)的構(gòu)造函數(shù)。

console.log(Foo.prototype.constructor === Foo);//true
console.log(f1.constructor === Foo);//true

5.ptoto:實(shí)例對(duì)象有一個(gè)proto屬性,指向該實(shí)例對(duì)象對(duì)應(yīng)的原型對(duì)象。

console.log(f1.__proto__ === Foo.prototype);//true
第一部分:Foo

1、實(shí)例對(duì)象f1是通過(guò)構(gòu)造函數(shù)Foo()new操作創(chuàng)建的。構(gòu)造函數(shù)Foo()的原型對(duì)象是Foo.prototype;實(shí)例對(duì)象f1通過(guò)proto屬性也指向原型對(duì)象Foo.prototype

console.log(f1.__proto === Foo.prototype);//true

2、實(shí)例對(duì)象f1本身并沒(méi)有constructor屬性,但它可以繼承原型對(duì)象Foo.prototypeconstructor屬性

console.log(Foo.prototype.constructor === Foo);//true
console.log(f1.constructor === Foo);//true
console.log(f1.hasOwnProperty("constructor"));//false

實(shí)例對(duì)象f1的控制臺(tái)效果

第二部分:Object

1、Foo.prototypef1的原型對(duì)象,同時(shí)它也是實(shí)例對(duì)象。實(shí)際上,任何對(duì)象都可以看做是通過(guò)Object()構(gòu)造函數(shù)的new操作實(shí)例化的對(duì)象 所以,Foo.prototype作為實(shí)例對(duì)象,它的構(gòu)造函數(shù)是Object(),原型對(duì)象是Object.prototype。相應(yīng)地,構(gòu)造函數(shù)Object()prototype屬性指向原型對(duì)象Object.prototype;實(shí)例對(duì)象Foo.prototypeproto屬性同樣指向原型對(duì)象Object.prototype

console.log(Foo.prototype.__proto__ === Object.prototype);//true

2、實(shí)例對(duì)象Foo.prototype本身具有constructor屬性,所以它會(huì)覆蓋繼承自原型對(duì)象Object.prototypeconstructor屬性。

console.log(Foo.prototype.constructor === Foo);//true
console.log(Object.prototype.constructor === Object);//true
console.log(Foo.prototype.hasOwnProperty("constructor"));//true

下圖是實(shí)例對(duì)象Foo.prototype的控制臺(tái)效果

3、Object.prototype作為實(shí)例對(duì)象的話,其原型對(duì)象是null。

console.log(Object.prototype.__proto__ === null);//true
第三部分:Function

1、前面已經(jīng)介紹過(guò),函數(shù)也是對(duì)象,只不過(guò)是具有特殊功能的對(duì)象而已。任何函數(shù)都可以看做是通過(guò)Function()構(gòu)造函數(shù)的new操作實(shí)例化的結(jié)果。如果把函數(shù)Foo當(dāng)成實(shí)例對(duì)象的話,其構(gòu)造函數(shù)是Function(),其原型對(duì)象是Function.prototype;類似地,函數(shù)Object的構(gòu)造函數(shù)也是Function(),其原型對(duì)象是Function.prototype

console.log(Foo.__proto__ === Function.prototype);//true
console.log(Object.__proto__ === Function.prototype);//true

2、原型對(duì)象Function.prototypeconstructor屬性指向構(gòu)造函數(shù)Function();實(shí)例對(duì)象ObjectFoo本身沒(méi)有constructor屬性,需要繼承原型對(duì)象Function.prototypeconstructor屬性。

console.log(Function.prototype.constructor === Function);//true
console.log(Foo.constructor === Function);//true
console.log(Foo.hasOwnProperty("constructor"));//false
console.log(Object.constructor === Function);//true
console.log(Object.hasOwnProperty("constructor"));//false

3、所有的函數(shù)都可以看成是構(gòu)造函數(shù)Function()new操作的實(shí)例化對(duì)象。那么,Function可以看成是調(diào)用其自身的new操作的實(shí)例化的結(jié)果。所以,如果Function作為實(shí)例對(duì)象,其構(gòu)造函數(shù)是Function,其原型對(duì)象是Function.prototype。

console.log(Function.__proto__ === Function.prototype);//true
console.log(Function.prototype.constructor === Function);//true
console.log(Function.prototype === Function.prototype);//true

4、如果Function.prototype作為實(shí)例對(duì)象的話,其原型對(duì)象是什么呢?和前面一樣,所有的對(duì)象都可以看成是Object()構(gòu)造函數(shù)的new操作的實(shí)例化結(jié)果。所以,Function.prototype的原型對(duì)象是Object.prototype,其原型函數(shù)是Object()。

console.log(Function.prototype.__proto__ === Object.prototype);//true
總結(jié):

1、函數(shù)(Function也是函數(shù))是new Function的結(jié)果,所以函數(shù)可以作為實(shí)例對(duì)象,其構(gòu)造函數(shù)是Function(),原型對(duì)象是Function.prototype;
2、對(duì)象(函數(shù)也是對(duì)象)是new Object的結(jié)果,所以對(duì)象可以作為實(shí)例對(duì)象,其構(gòu)造函數(shù)是Object(),原型對(duì)象是Object.prototype;
3、Object.prototype的原型對(duì)象是ull。

文章版權(quán)歸作者所有,未經(jīng)允許請(qǐng)勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。

轉(zhuǎn)載請(qǐng)注明本文地址:http://systransis.cn/yun/108863.html

相關(guān)文章

  • 重學(xué)前端學(xué)習(xí)筆記(八)--JavaScript原型和類

    摘要:用構(gòu)造器模擬類的兩種方法在構(gòu)造器中修改,給添加屬性修改構(gòu)造器的屬性指向的對(duì)象,它是從這個(gè)構(gòu)造器構(gòu)造出來(lái)的所有對(duì)象的原型。 筆記說(shuō)明 重學(xué)前端是程劭非(winter)【前手機(jī)淘寶前端負(fù)責(zé)人】在極客時(shí)間開(kāi)的一個(gè)專欄,每天10分鐘,重構(gòu)你的前端知識(shí)體系,筆者主要整理學(xué)習(xí)過(guò)程的一些要點(diǎn)筆記以及感悟,完整的可以加入winter的專欄學(xué)習(xí)【原文有winter的語(yǔ)音】,如有侵權(quán)請(qǐng)聯(lián)系我,郵箱:kai...

    nanfeiyan 評(píng)論0 收藏0
  • 重學(xué)前端學(xué)習(xí)筆記(八)--JavaScript原型和類

    摘要:用構(gòu)造器模擬類的兩種方法在構(gòu)造器中修改,給添加屬性修改構(gòu)造器的屬性指向的對(duì)象,它是從這個(gè)構(gòu)造器構(gòu)造出來(lái)的所有對(duì)象的原型。 筆記說(shuō)明 重學(xué)前端是程劭非(winter)【前手機(jī)淘寶前端負(fù)責(zé)人】在極客時(shí)間開(kāi)的一個(gè)專欄,每天10分鐘,重構(gòu)你的前端知識(shí)體系,筆者主要整理學(xué)習(xí)過(guò)程的一些要點(diǎn)筆記以及感悟,完整的可以加入winter的專欄學(xué)習(xí)【原文有winter的語(yǔ)音】,如有侵權(quán)請(qǐng)聯(lián)系我,郵箱:kai...

    k00baa 評(píng)論0 收藏0
  • 重學(xué)前端學(xué)習(xí)筆記(八)--JavaScript原型和類

    摘要:用構(gòu)造器模擬類的兩種方法在構(gòu)造器中修改,給添加屬性修改構(gòu)造器的屬性指向的對(duì)象,它是從這個(gè)構(gòu)造器構(gòu)造出來(lái)的所有對(duì)象的原型。 筆記說(shuō)明 重學(xué)前端是程劭非(winter)【前手機(jī)淘寶前端負(fù)責(zé)人】在極客時(shí)間開(kāi)的一個(gè)專欄,每天10分鐘,重構(gòu)你的前端知識(shí)體系,筆者主要整理學(xué)習(xí)過(guò)程的一些要點(diǎn)筆記以及感悟,完整的可以加入winter的專欄學(xué)習(xí)【原文有winter的語(yǔ)音】,如有侵權(quán)請(qǐng)聯(lián)系我,郵箱:kai...

    Render 評(píng)論0 收藏0
  • javascript對(duì)象和原型對(duì)象學(xué)習(xí)筆記

    摘要:例例通過(guò)原型鏈來(lái)檢測(cè)對(duì)象所調(diào)用的方法是否存在,存在在哪個(gè)原型對(duì)象上除了在對(duì)象對(duì)象中存在外,其他方法都是通過(guò)原型鏈的方法在上找到并調(diào)用。 前言 學(xué)習(xí)了解JavaScript對(duì)象的繼承機(jī)制 JavaScript Object 概念 Object是js的基本數(shù)據(jù)結(jié)構(gòu)的一種,屬于引用類型。 對(duì)象的創(chuàng)建方法 對(duì)象字面量寫法 構(gòu)造函數(shù),通過(guò)構(gòu)造函數(shù)來(lái)創(chuàng)建對(duì)象實(shí)例 Object()構(gòu)造函數(shù) cre...

    niceforbear 評(píng)論0 收藏0
  • JavaScript學(xué)習(xí)第十天筆記(繼承)

    摘要:繼承原型鏈如果構(gòu)造函數(shù)或?qū)ο蟮脑椭赶驑?gòu)造函數(shù)或?qū)ο?,的原型再指向?gòu)造函數(shù)或?qū)ο?,以此類推,最終的構(gòu)造函數(shù)或?qū)ο蟮脑椭赶虻脑汀? 繼承 原型鏈 如果構(gòu)造函數(shù)或?qū)ο驛的原型指向構(gòu)造函數(shù)或?qū)ο驜,B的原型再指向構(gòu)造函數(shù)或?qū)ο驝,以此類推,最終的構(gòu)造函數(shù)或?qū)ο蟮脑椭赶騉bject的原型。由此形成了一條鏈狀結(jié)構(gòu),被稱之為原型鏈。按照上述的描述,在B中定義的屬性或方法,可以在A中使用并不需要...

    baiy 評(píng)論0 收藏0

發(fā)表評(píng)論

0條評(píng)論

最新活動(dòng)
閱讀需要支付1元查看
<