原型與原型鏈

原型

每個(gè)構(gòu)造函數(shù)都有一個(gè)原型對(duì)象铁瞒,原型對(duì)象都包含一個(gè)指向構(gòu)造函數(shù)的指針萎坷,而實(shí)例都包含一個(gè)指向原型對(duì)象的內(nèi)部指針稀余。

實(shí)例對(duì)象有個(gè)屬性[prototype]国葬,叫做(__ proto__),實(shí)例對(duì)象可以通過(guò)這個(gè)屬性訪問(wèn)原型對(duì)象上的屬性和方法

var M = function (name) {
  this.name = name
}
var o = new M('o')
o.__proto__// 原型對(duì)象
原型鏈

假如我們讓原型對(duì)象等于另一個(gè)類型的實(shí)例未辆,此時(shí)的原型對(duì)象講包含在一個(gè)指向另一個(gè)原型的指針窟绷,相應(yīng)的,另一個(gè)原型中也包含著一個(gè)指向另一個(gè)構(gòu)造函數(shù)的指針咐柜。這樣層層遞進(jìn)钾麸,就狗證了實(shí)例與原型的鏈條,就是所謂的原型鏈炕桨。

var M = function (name) {
  this.name = name
}
var o = new M('o')
M.prototype.say=function(){
  console.log(this.name)
}
o.say(); // o
M.__proto__ === Function.prototype; // true
M.prototype.constructor === M; // true

原型鏈
function Parent() {
  this.name='parent';
  this.home='home';
}
function Child(){
  Parent.call(this)
  this.type = 'chile'
}
var child= new Child();
console.log(child.home); //home

上例中饭尝,Child類繼承了Parent類,而child是Child類的一個(gè)實(shí)例献宫,當(dāng)我們想打印child.home時(shí)钥平,首先在對(duì)象內(nèi)部尋找該屬性,直至找不到,然后才在該對(duì)象的原型(child.prototype)里去找這個(gè)屬性,Child沒(méi)有home屬性姊途,則從實(shí)例的child.proto(指向其構(gòu)造函數(shù)Child.prototype對(duì)象)對(duì)象中查找涉瘾,此時(shí),Child中也沒(méi)有次屬性,就再向上一級(jí)child.proto.proto也就是Parent的原型對(duì)象上找捷兰,就找到了Parent上的home屬性立叛。

創(chuàng)建對(duì)象的方法
1.字面量 
var o1 = {name:'o1'} 
var o2 = new Object({name: 'o2'})
2.顯示構(gòu)造函數(shù) 
var M = function(name) {this.name = name}
var o3 = new M('o3')
3.Object.create
var p = {name:'p'}
var o4 = Object.create(p)
o4.__proto__ === p //true
instanceof原理
instanceof

instanceof 運(yùn)算符用來(lái)判斷實(shí)例對(duì)象的proto屬性和構(gòu)造函數(shù)的prototype是否是同一個(gè)引用。instanceof 主要的實(shí)現(xiàn)原理就是只要右邊變量的 prototype 在左邊變量的原型鏈上即可贡茅。

var M = function(name) {this.name = name}
var o5 = new M('o5')
o5 instanceof M; // true
o5 instanceof Object; // true
o5.__proto__ === M.prototype; // true
M.prototype.__proto__ === Object.prototype; // true
o5.__proto__.constructor === M; // true
o5.__proto__.constructor === Object; // false
// 用constructor 判斷構(gòu)造函數(shù)直接生成的實(shí)例對(duì)象更為嚴(yán)謹(jǐn)秘蛇。
new一個(gè)對(duì)象的過(guò)程
function M(name) {
  this.name = name
  //return this
}
var m = new M('m1');
console.log(m.name);//m1

1.創(chuàng)建一個(gè)新對(duì)象
2.this 指向這個(gè)新對(duì)象
3.執(zhí)行代碼其做,即對(duì) this 賦值
4.返回 this(若返回值不為對(duì)象時(shí))

// 模擬new運(yùn)算符的工作原理
var new2 = function(fun) {
    var o = Object.create(fun.prototype)
    var k = fun.call(o)
    if(typeof k === 'object') {
        return k;
    } else {
        return o;
    }
}
var o6 = new2(M)
o6.intanceof(M) //true
o6.__proto__.constructor === M //true
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個(gè)濱河市赁还,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌艘策,老刑警劉巖蹈胡,帶你破解...
    沈念sama閱讀 217,084評(píng)論 6 503
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件朋蔫,死亡現(xiàn)場(chǎng)離奇詭異,居然都是意外死亡驯妄,警方通過(guò)查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,623評(píng)論 3 392
  • 文/潘曉璐 我一進(jìn)店門富玷,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái)既穆,“玉大人,你說(shuō)我怎么就攤上這事幻工。” “怎么了囊颅?”我有些...
    開(kāi)封第一講書人閱讀 163,450評(píng)論 0 353
  • 文/不壞的土叔 我叫張陵当悔,是天一觀的道長(zhǎng)。 經(jīng)常有香客問(wèn)我踢代,道長(zhǎng)盲憎,這世上最難降的妖魔是什么? 我笑而不...
    開(kāi)封第一講書人閱讀 58,322評(píng)論 1 293
  • 正文 為了忘掉前任胳挎,我火速辦了婚禮饼疙,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘慕爬。我一直安慰自己窑眯,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,370評(píng)論 6 390
  • 文/花漫 我一把揭開(kāi)白布医窿。 她就那樣靜靜地躺著磅甩,像睡著了一般。 火紅的嫁衣襯著肌膚如雪姥卢。 梳的紋絲不亂的頭發(fā)上卷要,一...
    開(kāi)封第一講書人閱讀 51,274評(píng)論 1 300
  • 那天渣聚,我揣著相機(jī)與錄音,去河邊找鬼却妨。 笑死饵逐,一個(gè)胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的彪标。 我是一名探鬼主播倍权,決...
    沈念sama閱讀 40,126評(píng)論 3 418
  • 文/蒼蘭香墨 我猛地睜開(kāi)眼,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼捞烟!你這毒婦竟也來(lái)了薄声?” 一聲冷哼從身側(cè)響起,我...
    開(kāi)封第一講書人閱讀 38,980評(píng)論 0 275
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤题画,失蹤者是張志新(化名)和其女友劉穎默辨,沒(méi)想到半個(gè)月后,有當(dāng)?shù)厝嗽跇?shù)林里發(fā)現(xiàn)了一具尸體苍息,經(jīng)...
    沈念sama閱讀 45,414評(píng)論 1 313
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡缩幸,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,599評(píng)論 3 334
  • 正文 我和宋清朗相戀三年,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了竞思。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片表谊。...
    茶點(diǎn)故事閱讀 39,773評(píng)論 1 348
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡,死狀恐怖盖喷,靈堂內(nèi)的尸體忽然破棺而出爆办,到底是詐尸還是另有隱情,我是刑警寧澤课梳,帶...
    沈念sama閱讀 35,470評(píng)論 5 344
  • 正文 年R本政府宣布距辆,位于F島的核電站,受9級(jí)特大地震影響暮刃,放射性物質(zhì)發(fā)生泄漏跨算。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,080評(píng)論 3 327
  • 文/蒙蒙 一椭懊、第九天 我趴在偏房一處隱蔽的房頂上張望漂彤。 院中可真熱鬧,春花似錦灾搏、人聲如沸挫望。這莊子的主人今日做“春日...
    開(kāi)封第一講書人閱讀 31,713評(píng)論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)。三九已至奕纫,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間匹层,已是汗流浹背。 一陣腳步聲響...
    開(kāi)封第一講書人閱讀 32,852評(píng)論 1 269
  • 我被黑心中介騙來(lái)泰國(guó)打工撑柔, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留铅忿,地道東北人。 一個(gè)月前我還...
    沈念sama閱讀 47,865評(píng)論 2 370
  • 正文 我出身青樓檀训,卻偏偏與公主長(zhǎng)得像峻凫,于是被迫代替她去往敵國(guó)和親担锤。 傳聞我的和親對(duì)象是個(gè)殘疾皇子乍钻,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 44,689評(píng)論 2 354

推薦閱讀更多精彩內(nèi)容