Javascript 面試題隨筆
var Fundamental = {count:1};
function Test(){}
Test.prototype = Fundamental;
Test.prototype.increase = function(){this.count++;};
var test = new Test();
console.log(test.count);
var test2 = new Test();
console.log(test2.count);
test.increase();
//test.count和test2.count的值各是多少
前天去面試遇到的一道題,面試的問題大概是當(dāng)test.increase被調(diào)用時(shí),test和test2的count值分別是多少
首先,回答這道題有可能把這種情況與另一種類似的情況相混淆:
假如把代碼改成:
function FundamentalModified(){
var count = 1;
this.increase = function(){
count++;
}
this.show = function(){
return count;
}
}
function TestModified(){}
TestModified.prototype = new FundamentalModified();
var test3 = new TestModified();
var test4 = new TestModified();
test3.increase();
//test3.show()和test4.show()各是多少
假如問題改成這樣,那就簡(jiǎn)單的多了。但是兩個(gè)問題并不會(huì)得到相同的結(jié)果。
==========================================分割一下
回到面試題中,其實(shí)面試題的答案是2和1。原因呢:test.count是test的屬性,而且test2.count其實(shí)是test2.__proto__的屬性:
當(dāng)test.increase()被調(diào)用時(shí),JS執(zhí)行了this.count++ ==> 返回this.count; this.count = this.count + 1;
this.count = this.count + 1;
這句在看似簡(jiǎn)單的語(yǔ)句其實(shí)有著不同尋常的意味~~
這句話的意思其實(shí)是,給實(shí)例新建一個(gè)屬性,這個(gè)屬性被賦予this.count + 1的值。
而this.count 其實(shí)是在原型鏈中的count,也就是這個(gè)this.count++其實(shí)在第一次執(zhí)行的時(shí)候表現(xiàn)為:
this.count = Test.Prototype.count + 1;
可以用hasOwnProperty來驗(yàn)證一下:
當(dāng)var test = new Test()時(shí)。test.hasOwnProperty("count") === false
test.increase()后。 test.hasOwnProperty("count") === true
總的來說,JS還是一個(gè)很好玩的語(yǔ)言。
相關(guān)文章
js實(shí)現(xiàn)同一頁(yè)面可多次調(diào)用的圖片幻燈切換效果
這篇文章主要介紹了js實(shí)現(xiàn)同一頁(yè)面可多次調(diào)用的圖片幻燈切換效果,可實(shí)現(xiàn)在同一頁(yè)面中多次調(diào)用幻燈切換效果,非常具有實(shí)用價(jià)值,需要的朋友可以參考下2015-02-02Javascript封裝DOMContentLoaded事件實(shí)例
這篇文章主要介紹了Javascript封裝DOMContentLoaded事件實(shí)例,DOMContentLoaded是FF,Opera 9的特有的Event, 當(dāng)所有DOM解析完以后會(huì)觸發(fā)這個(gè)事件,需要的朋友可以參考下2014-06-06JavaScript實(shí)現(xiàn)網(wǎng)頁(yè)電子時(shí)鐘
這篇文章主要為大家詳細(xì)介紹了JavaScript實(shí)現(xiàn)網(wǎng)頁(yè)電子時(shí)鐘,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2022-06-06解決typescript?提示?Object?is?possibly'null'的N種方案
這篇文章主要介紹了typescript?提示?Object?is?possibly?‘null‘?的N種解決方法,本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2023-03-03js String.prototype.trim字符去前后空格的擴(kuò)展
這篇文章主要介紹了js String.prototype.trim字符去前后空格的擴(kuò)展,需要的朋友可以參考下2020-04-04