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

資訊專(zhuān)欄INFORMATION COLUMN

JS之原型與原型鏈

Fourierr / 387人閱讀

摘要:因此,就會(huì)形成一個(gè)原型鏈對(duì)象到原型,再到原型的原型如果一層層地上溯,所有對(duì)象的原型最終都可以上溯到,即構(gòu)造函數(shù)的屬性。

對(duì)于很多前端開(kāi)發(fā)者而言,JavaScript中原型與原型鏈?zhǔn)且粋€(gè)比較容易疑惑的點(diǎn),所以本文記錄了自己對(duì)應(yīng)這方面的一點(diǎn)理解,以后有更深的理解再來(lái)更新。

對(duì)象

想要了解原型與原型鏈,首先要了解什么是對(duì)象?面向?qū)ο缶幊蹋∣bject Oriented Programming,縮寫(xiě)為 OOP)是目前主流的編程范式,即把實(shí)際上各種復(fù)雜關(guān)系抽象為多個(gè)對(duì)象后對(duì)它們進(jìn)行分工合作從而完成對(duì)現(xiàn)實(shí)環(huán)境的模擬。因此對(duì)象是單個(gè)實(shí)物的抽象,抽象所得的對(duì)象是一個(gè)容器,擁有屬性(property)和方法(method)。例如,我們把學(xué)生抽象為student對(duì)象,那么屬性就可以用來(lái)記錄具體是哪一個(gè)年級(jí)的學(xué)生(如初一、高一等),用方法來(lái)表示學(xué)生的某種行為(如學(xué)習(xí)、玩耍等)。

構(gòu)造函數(shù)(constructor)、實(shí)例對(duì)象與繼承

當(dāng)我們想要使用面向?qū)ο缶幊虝r(shí),首要任務(wù)是生成對(duì)象。在JavaScript中,構(gòu)造函數(shù)(constructor)就是專(zhuān)門(mén)用來(lái)生成實(shí)例對(duì)象的。一個(gè)構(gòu)造函數(shù),可以生成多個(gè)實(shí)例對(duì)象,這些實(shí)例對(duì)象都有相同的結(jié)構(gòu)。

var Student= function () {
  this.age= 18;
};

var s = new Student();
s.age// 18

特別需要注意的是:

以上代碼中,Student就是構(gòu)造函數(shù),但是為了與普通函數(shù)區(qū)分,其名字的首字母要大寫(xiě)。

函數(shù)體內(nèi)部使用了this關(guān)鍵字,代表了所要生成的對(duì)象實(shí)例。

生成對(duì)象的時(shí)候,必須使用new命令。只有new了才會(huì)生成新的實(shí)例對(duì)象。

除了用new命令生成新的實(shí)例對(duì)象,我們還可以通過(guò)Object.create() 來(lái)創(chuàng)建,這種方法適用于我們沒(méi)有辦法拿到構(gòu)造函數(shù)而只能拿到一個(gè)現(xiàn)有的對(duì)象。

var student1 = {
    name:"Solar",
    age:18,
    greeting:function(){
        console.log("Hello!");
    }
};
var student2 = Object.create(student1);
student2.name//Solar
student2.greeting()//Hello!

上面代碼中,Object.create方法以student1對(duì)象為原型,生成了student2對(duì)象。student2繼承了student1的所有屬性和方法。

原型對(duì)象(prototype)

首先讓我們來(lái)了解一下為什么會(huì)有原型對(duì)象(prototype)?

function Student(name, age) {
  this.name = name;
  this.age = age;
  this.greeting = function(){
    console.log("Hello!");
  }
}

var student1= new Student("Solar", "18");
var student2 = new Student("Moonbyul", "17");

student1.greeting=== student2.greeting
// false

從以上代碼可以看到,通過(guò)構(gòu)造函數(shù)實(shí)例出的對(duì)象,雖然都具有g(shù)reeting方法,但是因?yàn)檫@個(gè)方法是生成在自身的每個(gè)實(shí)例對(duì)象上,也就是每生成一個(gè)實(shí)例就會(huì)新建一個(gè)greeting方法。但是其實(shí)greeting方法都是同樣的,沒(méi)有必要多次生成造成資源浪費(fèi),于是JavaScript的原型對(duì)象就誕生了。JavaScript規(guī)定,每個(gè)函數(shù)都有一個(gè)prototype屬性,指向一個(gè)對(duì)象。

function Animal(name) {
  this.name = name;
}
Animal.prototype.color = "white";
var cat1 = new Animal("大毛");
var cat2 = new Animal("二毛");
cat1.color // "white"
cat2.color // "white"

上面代碼中,構(gòu)造函數(shù)Animal的prototype屬性,就是實(shí)例對(duì)象cat1和cat2的原型對(duì)象。原型對(duì)象上添加一個(gè)color屬性,結(jié)果,實(shí)例對(duì)象都共享了該屬性。

原型對(duì)象的屬性不是實(shí)例對(duì)象自身的屬性。只要修改原型對(duì)象,變動(dòng)就立刻會(huì)體現(xiàn)在所有實(shí)例對(duì)象上。

Animal.prototype.color = "yellow";
cat1.color // "yellow"
cat2.color // "yellow"

如果實(shí)例對(duì)象自身就有某個(gè)屬性或方法,它就不會(huì)再去原型對(duì)象尋找這個(gè)屬性或方法。

cat1.color = "black";
cat1.color // "black"
cat2.color // "yellow"
Animal.prototype.color // "yellow";
原型鏈(prototype chain)

JavaScript 規(guī)定,所有對(duì)象都有自己的原型對(duì)象(prototype)。一方面,任何一個(gè)對(duì)象,都可以充當(dāng)其他對(duì)象的原型;另一方面,由于原型對(duì)象也是對(duì)象,所以它也有自己的原型。因此,就會(huì)形成一個(gè)“原型鏈”(prototype chain):對(duì)象到原型,再到原型的原型……

如果一層層地上溯,所有對(duì)象的原型最終都可以上溯到Object.prototype,即Object構(gòu)造函數(shù)的prototype屬性。也就是說(shuō),所有對(duì)象都繼承了Object.prototype的屬性。Object.prototype的原型是null。null沒(méi)有任何屬性和方法,也沒(méi)有自己的原型。因此,原型鏈的盡頭就是null。

總結(jié)

記住下面幾句話(huà),這幾句話(huà)能解釋一切關(guān)于原型方面的問(wèn)題:
當(dāng) new 一個(gè)函數(shù)的時(shí)候會(huì)創(chuàng)建一個(gè)對(duì)象,『函數(shù).prototype』 等于 『被創(chuàng)建對(duì)象.__proto__』

一切函數(shù)都是由 Function 這個(gè)函數(shù)創(chuàng)建的,所以『Function.prototype === 被創(chuàng)建的函數(shù).__proto__』

一切函數(shù)的原型對(duì)象都是由 Object 這個(gè)函數(shù)創(chuàng)建的,所以『Object.prototype === 一切函數(shù).prototype.__proto__』

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

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

相關(guān)文章

  • 進(jìn)擊JavaScript(四)原型原型

    摘要:每一個(gè)由構(gòu)造函數(shù)創(chuàng)建的對(duì)象都會(huì)默認(rèn)的連接到該神秘對(duì)象上。在構(gòu)造方法中也具有類(lèi)似的功能,因此也稱(chēng)其為類(lèi)實(shí)例與對(duì)象實(shí)例一般是指某一個(gè)構(gòu)造函數(shù)創(chuàng)建出來(lái)的對(duì)象,我們稱(chēng)為構(gòu)造函數(shù)的實(shí)例實(shí)例就是對(duì)象。表示該原型是與什么構(gòu)造函數(shù)聯(lián)系起來(lái)的。 本文您將看到以下內(nèi)容: 傳統(tǒng)構(gòu)造函數(shù)的問(wèn)題 一些相關(guān)概念 認(rèn)識(shí)原型 構(gòu)造、原型、實(shí)例三角結(jié)構(gòu)圖 對(duì)象的原型鏈 函數(shù)的構(gòu)造函數(shù)Function 一句話(huà)說(shuō)明什么...

    XBaron 評(píng)論0 收藏0
  • Javascript重溫OOP原型原型

    摘要:在構(gòu)造函數(shù)中的中定義的屬性和方法,會(huì)被創(chuàng)建的對(duì)象所繼承下來(lái)。從上面的輸出結(jié)果看出,指向了其構(gòu)造函數(shù)的,而本身也是一個(gè)對(duì)象,其內(nèi)部也有屬性,其指向的是直到最后指向,這條原型鏈才結(jié)束。和都指向,說(shuō)明原型鏈到終止。 prototype原型對(duì)象 每個(gè)函數(shù)都有一個(gè)默認(rèn)的prototype屬性,其實(shí)際上還是一個(gè)對(duì)象,如果被用在繼承中,姑且叫做原型對(duì)象。 在構(gòu)造函數(shù)中的prototype中定義的屬性...

    lindroid 評(píng)論0 收藏0
  • 深入理解 js 繼承原型

    摘要:原型鏈與繼承當(dāng)談到繼承時(shí),只有一種結(jié)構(gòu)對(duì)象。如果對(duì)該圖不怎么理解,不要著急,繼續(xù)往下看基于原型鏈的繼承對(duì)象是動(dòng)態(tài)的屬性包指其自己的屬性。當(dāng)使用操作符來(lái)作用這個(gè)函數(shù)時(shí),它就可以被稱(chēng)為構(gòu)造方法構(gòu)造函數(shù)。 原型鏈與繼承 當(dāng)談到繼承時(shí),JavaScript 只有一種結(jié)構(gòu):對(duì)象。每個(gè)實(shí)例對(duì)象(object )都有一個(gè)私有屬性(稱(chēng)之為proto)指向它的原型對(duì)象(prototype)。該原型對(duì)象也...

    xingqiba 評(píng)論0 收藏0
  • JS面向?qū)ο蟮某绦蛟O(shè)計(jì)繼承的實(shí)現(xiàn) - 原型

    摘要:簡(jiǎn)單回顧一下構(gòu)造函數(shù)原型和實(shí)例對(duì)象之間的關(guān)系每個(gè)構(gòu)造函數(shù)都有一個(gè)原型對(duì)象。找到生成構(gòu)造函數(shù)的原型對(duì)象的構(gòu)造函數(shù),搜索其原型對(duì)象,找到了。 JS面向?qū)ο蟮某绦蛟O(shè)計(jì)之繼承的實(shí)現(xiàn) - 原型鏈 前言:最近在細(xì)讀Javascript高級(jí)程序設(shè)計(jì),對(duì)于我而言,中文版,書(shū)中很多地方翻譯的差強(qiáng)人意,所以用自己所理解的,嘗試解讀下。如有紕漏或錯(cuò)誤,會(huì)非常感謝您的指出。文中絕大部分內(nèi)容引用自《JavaS...

    zhaochunqi 評(píng)論0 收藏0
  • 深入學(xué)習(xí)js——原型原型

    摘要:我們用一張圖表示構(gòu)造函數(shù)和實(shí)例原型之間的關(guān)系好了構(gòu)造函數(shù)和實(shí)例原型之間的關(guān)系我們已經(jīng)梳理清楚了,那我們?cè)趺幢硎緦?shí)例與實(shí)例原型,也就是或者和之間的關(guān)系呢。 開(kāi)篇: 在Brendan Eich大神為JavaScript設(shè)計(jì)面向?qū)ο笙到y(tǒng)的時(shí)候,借鑒了Self 和Smalltalk這兩門(mén)基于原型的語(yǔ)言,之所以選擇基于原型的面向?qū)ο笙到y(tǒng),并不是因?yàn)闀r(shí)間匆忙,它設(shè)計(jì)起來(lái)相對(duì)簡(jiǎn)單,而是因?yàn)閺囊婚_(kāi)始B...

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

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

0條評(píng)論

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