成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

圖解Javascript原型(prototype)鏈

開(kāi)發(fā) 后端
本文嘗試闡述Js中原型(prototype)、原型鏈(prototype chain)等概念及其作用機(jī)制。

 本文嘗試闡述Js中原型(prototype)、原型鏈(prototype chain)等概念及其作用機(jī)制。

 

[[167207]]

我們知道,在Js中一切皆為對(duì)象(Object),但是Js中并沒(méi)有類(class);Js是基于原型(prototype-based)來(lái)實(shí)現(xiàn)的面向?qū)ο?OOP)的編程范式的,但并不是所有的對(duì)象都擁有 prototype 這一屬性:

var a = {};

console.log(a.prototype); //=> undefined

var b = function(){};

console.log(b.prototype); //=> {}

var c = 'Hello';

console.log(c.prototype); //=> undefined

prototype 是每個(gè) function 定義時(shí)自帶的屬性,但是Js中 function 本身也是對(duì)象,我們先來(lái)看一下下面幾個(gè)概念的差別:

1. function 、 Function 、 Object 和 {}

function 是Js的一個(gè)關(guān)鍵詞,用于定義函數(shù)類型的變量,有兩種語(yǔ)法形式:

function f1(){

console.log('This is function f1!');

}

typeof(f1); //=> 'function'

var f2 = function(){

console.log('This is function f2!');

}

typeof(f2); //=> 'function'

如果用更加面向?qū)ο蟮姆椒▉?lái)定義函數(shù),可以用 Function :

var f3 = new Function("console.log('This is function f3!');");

f3(); //=> 'This is function f3!'

typeof(f3); //=> 'function'

typeof(Function); //=> 'function'

實(shí)際上 Function 就是一個(gè)用于構(gòu)造函數(shù)類型變量的類,或者說(shuō)是函數(shù)類型實(shí)例的構(gòu)造函數(shù)(constructor);與之相似有的 Object 或 String 、 Number 等,都是Js內(nèi)置類型實(shí)例的構(gòu)造函數(shù)。比較特殊的是 Object ,它用于生成對(duì)象類型,其簡(jiǎn)寫(xiě)形式為 {} :

var o1 = new Object();

typeof(o1); //=> 'object'

var o2 = {};

typeof(o2); //=> 'object'

typeof(Object); //=> 'function'

2. prototype VS __proto__

清楚了上面的概念之后再來(lái)看 prototype :

Each function has two properties: length and prototype

prototype 和 length 是每一個(gè)函數(shù)類型自帶的兩個(gè)屬性,而其它非函數(shù)類型并沒(méi)有(開(kāi)頭的例子已經(jīng)說(shuō)明),這一點(diǎn)之所以比較容易被忽略或誤解,是因?yàn)樗蓄愋偷臉?gòu)造函數(shù)本身也是函數(shù),所以它們自帶了 prototype 屬性:

// Node

console.log(Object.prototype); //=> {}

console.log(Function.prototype);//=> [Function: Empty]

console.log(String.prototype); //=> [String: '']

除了 prototype 之外,Js中的所有對(duì)象( undefined 、 null 等特殊情況除外)都有一個(gè)內(nèi)置的 [[Prototype]] 屬性,指向它“父類”的 prototype ,這個(gè)內(nèi)置屬性在ECMA標(biāo)準(zhǔn)中并沒(méi)有給出明確的獲取方式,但是許多Js的實(shí)現(xiàn)(如Node、大部分瀏覽器等)都提供了一個(gè) __proto__ 屬性來(lái)指代這一 [[Prototype]] ,我們通過(guò)下面的例子來(lái)說(shuō)明實(shí)例中的 __proto__ 是如何指向構(gòu)造函數(shù)的 prototype的:

var Person = function(){};

Person.prototype.type = 'Person';

Person.prototype.maxAge = 100;

var p = new Person();

console.log(p.maxAge);

p.name = 'rainy';

Person.prototype.constructor === Person; //=> true

p.__proto__ === Person.prototype; //=> true

console.log(p.prototype); //=> undefined

上面的代碼示例可以用下圖解釋:

Person 是一個(gè)函數(shù)類型的變量,因此自帶了 prototype 屬性, prototype 屬性中的 constructor 又指向 Person 本身;通過(guò) new 關(guān)鍵字生成的 Person 類的實(shí)例 p1 ,通過(guò) __proto__ 屬性指向了 Person 的原型。這里的 __proto__ 只是為了說(shuō)明實(shí)例 p1 在內(nèi)部實(shí)現(xiàn)的時(shí)候與父類之間存在的關(guān)聯(lián)(指向父類的原型),在實(shí)際操作過(guò)程中實(shí)例可以直接通過(guò) . 獲取父類原型中的屬性,從而實(shí)現(xiàn)了繼承的功能。

3. 原型鏈

清楚了 prototype 與 __proto__ 的概念與關(guān)系之后我們會(huì)對(duì)“Js中一切皆為對(duì)象”這句話有更加深刻的理解。進(jìn)而我們會(huì)想到,既然 __proto__ 是(幾乎)所有對(duì)象都內(nèi)置的屬性,而且指向父類的原型,那是不是意味著我們可以“逆流而上”一直找到源頭呢?我們來(lái)看下面的例子:

// Node

var Obj = function(){};

var o = new Obj();

o.__proto__ === Obj.prototype; //=> true

o.__proto__.constructor === Obj; //=> true

Obj.__proto__ === Function.prototype; //=> true

Obj.__proto__.constructor === Function; //=> true

Function.__proto__ === Function.prototype; //=> true

Object.__proto__ === Object.prototype; //=> false

Object.__proto__ === Function.prototype; //=> true

Function.__proto__.constructor === Function;//=> true

Function.__proto__.__proto__; //=> {}

Function.__proto__.__proto__ === o.__proto__.__proto__; //=> true

o.__proto__.__proto__.__proto__ === null; //=> true

從上面的例子和圖解可以看出, prototype 對(duì)象也有 __proto__ 屬性,向上追溯一直到 null 。

new 關(guān)鍵詞的作用就是完成上圖所示實(shí)例與父類原型之間關(guān)系的串接,并創(chuàng)建一個(gè)新的對(duì)象; instanceof 關(guān)鍵詞的作用也可以從上圖中看出,實(shí)際上就是判斷__proto__ (以及 __proto__.__proto__ …)所指向是否父類的原型:

var Obj = function(){};

var o = new Obj();

o instanceof Obj; //=> true

o instanceof Object; //=> true

o instanceof Function; //=> false

o.__proto__ === Obj.prototype; //=> true

o.__proto__.__proto__ === Object.prototype; //=> true

o.__proto__.__proto__ === Function; //=> false

責(zé)任編輯:趙立京 來(lái)源: 程序師
相關(guān)推薦

2020-09-10 07:04:30

JSJavaScript 原型鏈

2023-08-28 07:12:54

2020-02-20 14:00:15

JavaScript原型原型鏈

2017-04-07 11:15:49

原型鏈原型Javascript

2022-05-26 09:20:01

JavaScript原型原型鏈

2020-10-20 08:35:34

JS基礎(chǔ)進(jìn)階

2022-06-20 09:22:55

js原型鏈前端

2012-11-08 10:40:47

JavaScript原型鏈

2016-05-06 14:02:18

JavaScript原型鏈

2024-08-09 12:44:45

JavaScript原型鏈鏈條

2012-01-05 15:07:11

JavaScript

2021-05-18 08:52:31

Prototype 原型模式設(shè)計(jì)模式

2017-05-05 10:31:35

JavaScriptprototype__proto__

2022-04-14 20:43:24

JavaScript原型鏈

2022-03-29 09:15:55

Javascript函數(shù)屬性

2021-10-20 18:44:43

編程對(duì)象JavaScript

2016-12-27 09:10:29

JavaScript原型鏈繼承

2019-02-27 16:00:48

JS原型原型鏈對(duì)象

2011-08-31 14:48:33

JavaScript

2024-08-27 12:36:33

點(diǎn)贊
收藏

51CTO技術(shù)棧公眾號(hào)

主站蜘蛛池模板: 国产欧美精品一区二区三区 | 国产高清一区二区三区 | 黄色网址在线免费观看 | 国产乱码精品一区二区三区中文 | 国产小视频在线观看 | 国产伦精品一区二区三毛 | 亚洲成人网在线观看 | 成人在线观看免费视频 | 美女爽到呻吟久久久久 | 久久99国产精一区二区三区 | 人人人人干 | 亚洲一区二区三区免费视频 | 午夜视频在线视频 | 国产精品视频网 | 国产精品一区二区视频 | jlzzjlzz欧美大全 | 国产无套一区二区三区久久 | 亚洲国产精品视频一区 | aa级毛片毛片免费观看久 | 国产精品三级久久久久久电影 | 日韩精彩视频 | 免费观看a级毛片在线播放 黄网站免费入口 | 亚洲一区欧美 | 中文字幕不卡在线观看 | 爱爱视频网 | 九九热久久免费视频 | 午夜免费福利片 | 黄色网页在线 | 欧美性一区二区三区 | 中文字幕在线一区 | 韩国av一区二区 | 一区二区精品在线 | 欧美在线观看一区 | 国产中文在线观看 | 日韩在线观看网站 | 亚洲国产成人精品女人久久久 | 亚洲国产aⅴ成人精品无吗 综合国产在线 | 日韩av中文 | 亚洲欧美另类在线 | 精品久久九九 | 亚洲精品国产一区 |