国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁(yè) > 編程 > JavaScript > 正文

JS原型與原型鏈的深入理解

2019-11-19 17:34:44
字體:
來(lái)源:轉(zhuǎn)載
供稿:網(wǎng)友

要了解原型和原型鏈,首先要理解普通對(duì)象和函數(shù)對(duì)象。

一、普通對(duì)象和函數(shù)對(duì)象的區(qū)別

在Javascript的世界里,全都是對(duì)象,而對(duì)象之間也是存在區(qū)別,我們首先區(qū)分一下普通對(duì)象和函數(shù)對(duì)象,如下代碼:

function f1(){};var f2 = function(){};var f3 = new function(){};var o1 = {};var o2 = new Object();var o3 = new f1();console.log(typeof Object); //functionconsole.log(typeof Function);//functionconsole.log(typeof f1) //functionconsole.log(typeof f2) // functionconsole.log(typeof f3) //functionconsole.log(typeof o1) //objectconsole.log(typeof o2) //objectconsole.log(typeof o3)// object

在上面的代碼中可以看出,f1、f2和f3都是函數(shù)對(duì)象,而o1,o2和o3都是object對(duì)象,也就是普通對(duì)象,函數(shù)對(duì)象本質(zhì)就是由new function()構(gòu)造而來(lái),其他的都是普通對(duì)象;函數(shù)對(duì)象和普通對(duì)象理解之后,后文會(huì)說(shuō)明兩者的區(qū)別。

二、原型

在JavaScript中,原型也是一個(gè)對(duì)象,原型的作用,則是實(shí)現(xiàn)對(duì)象的繼承。

在js的所有函數(shù)對(duì)象中,都存在一個(gè)屬性prototype,該屬性對(duì)應(yīng)當(dāng)前對(duì)象的原型。

而所有的JavaScript對(duì)象,都存在一個(gè)_proto_屬性(由于_proto_是個(gè)非標(biāo)準(zhǔn)屬性,因此只有ff和chrome兩個(gè)瀏覽器支持,標(biāo)準(zhǔn)方法是Object.getPrototypeOf()),_proto_屬性指向?qū)嵗龑?duì)象的構(gòu)造函數(shù)的原型,理解起來(lái)就如下:

var p = new Person(); console.log(p._proto === Person.prototype)//true 

從上面代碼可以看出,p是實(shí)例對(duì)象,Person是p的構(gòu)造函數(shù),可以看出來(lái)p的_proto_屬性指向構(gòu)造函數(shù)Person的原型。

下面用代碼來(lái)解釋一下js是如何通過(guò)原型進(jìn)行繼承的:

var parent = function(name){ this.name = name;}parent.prototype.getName = function(){ return this.name;}var son = new parent("huahua");console.log(son.getName());//'huahua'

顯然,son繼承了parent的原型中的函數(shù)屬性getName。

三、原型鏈

除開Object的prototype的原型是null以外,所有的對(duì)象和原型都有自己的原型,對(duì)象的原型指向原型對(duì)象。

在層級(jí)多的關(guān)系中,多個(gè)原型層層相連則構(gòu)成了原型鏈。

在查找一個(gè)對(duì)象的屬性時(shí),倘若在當(dāng)前對(duì)象找不到該屬性,則會(huì)沿著原型鏈一直往上查找,知道找到為止,如果到了原型鏈頂端,還沒找到,則返回undefined。

四、constructor

constructor是構(gòu)造函數(shù)創(chuàng)建的實(shí)例的屬性,該屬性的作用是指向創(chuàng)建當(dāng)前對(duì)象的構(gòu)造函數(shù)。

例如,son.constructor == parent;//true

以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持武林網(wǎng)。

發(fā)表評(píng)論 共有條評(píng)論
用戶名: 密碼:
驗(yàn)證碼: 匿名發(fā)表
主站蜘蛛池模板: 曲靖市| 太保市| 海阳市| 兴国县| 达日县| 赤峰市| 浦东新区| 余姚市| 兴城市| 西昌市| 五家渠市| 莱州市| 佛冈县| 柞水县| 定西市| 苗栗县| 屯留县| 海丰县| 湖北省| 通江县| 靖宇县| 宜昌市| 天水市| 嵩明县| 花莲市| 手游| 年辖:市辖区| 莱阳市| 鄄城县| 乌兰县| 镇坪县| 历史| 扎赉特旗| 汝州市| 游戏| 阿克苏市| 沂水县| 昌宁县| 凤庆县| 临高县| 潢川县|