javascript - js中單例模式疑惑
問題描述
以下代碼
function Universe() { // 緩存的實例 var instance = this; // 其它內(nèi)容 this.start_time = 0; this.bang = 'Big'; // 重寫構(gòu)造函數(shù) Universe = function () {return instance; };}// 測試var uni = new Universe();var uni2 = new Universe();uni.bang = '123';console.log(uni === uni2); // trueconsole.log(uni2.bang); // 123
點擊查看原文
問題:
new Universe()的過程是:var o = {};Universe.call(o);//這一步是將Universe中this對應(yīng)的屬性賦值給o;o.__proto__ = Universe.prototype;//將Universe原型上的方法賦值到o的__proto__屬性上;
那么 var instance = this;中,this是不是指的是不同的對象o?那么重寫構(gòu)造函數(shù)后,返回的instance不就是不同的對象嗎?為什么最后能相等
問題解答
回答1:因為重寫了構(gòu)造函數(shù)后, 返回一個對象, 這個對象會覆蓋你 用new 構(gòu)造函數(shù)生成的那個對象,不知道我有沒有說清楚
回答2:@mpccc 說的對。
如果構(gòu)造函數(shù)返回一個對象,那 new 出來的就是這個對象啦。
可以看看秘密花園中的構(gòu)造函數(shù)這一段
回答3:我也是新手,嘗試解答一下,要是錯了可別怪我
第一 this是不是指的是不同的對象 在第一次調(diào)用構(gòu)造函數(shù)的時候 產(chǎn)生一個空的對象 并且函數(shù)內(nèi)部的this指向了這個空對象,接著執(zhí)行代碼,最后返回這個對象 也就是uni。
而在第二次調(diào)用的時候由于第一次函數(shù)的改寫,產(chǎn)生了一個閉包,這個閉包的內(nèi)部的instance正好指向了第一次調(diào)用時的產(chǎn)生的對象uni,當(dāng)?shù)诙螆?zhí)行new Universe()的時候你執(zhí)行的是一個閉包,也會產(chǎn)生一個空的對象,但那個對象并沒有用到它,反而是直接返回了閉包內(nèi)部的instance也就是uni。
所以uni2 === uni.
回答4:偏個題,這樣寫單例模式有點多余,要創(chuàng)建唯一的對象不用非得造個構(gòu)造函數(shù)
var single = function(fn){ var instance; return function(){ return instance || (instance = fn .apply(this, arguments)); } }; 回答5:
不是注釋寫了嗎,重寫了構(gòu)造函數(shù)啊,你new了一次之后再new就沒有var instance = this;這行代碼了,instance自然就不變了
//簡單打印一下就知道了console.log(Universe)var uni = new Universe()console.log(Universe)回答6:
首次執(zhí)行new Universe()的時候,確實產(chǎn)生了一個新的this,并且將Universe構(gòu)造函數(shù)改寫了,之后再次調(diào)用這個new Universe()的時候,就只會return instance了,不會產(chǎn)生新的對象了。
相關(guān)文章:
1. mysql - 數(shù)據(jù)庫建表方面的問題?2. javascript - angular里一個關(guān)于ng-bind的問題3. mysql - 我用SQL語句 更新 行的時候,發(fā)現(xiàn)全部 中文都被清空了,請問怎么解決?4. python - xpath提取網(wǎng)頁路徑?jīng)]問題,但是缺失內(nèi)容?5. javascript - IOS微信audio標(biāo)簽不能通過touchend播放6. [前端求職必看]前端開發(fā)面試題與答案精選_大綱7. java中這個頁面默認(rèn)是utf-8編碼的,1輸出亂碼可以理解,可是2就不理解了?8. javascript - 求教各位,本地HTML頁面怎么在DIV中嵌套服務(wù)器上的頁面內(nèi)容?不用iframe。9. python-mysql Commands out of sync10. javascript - angularJS指令如何暴露API給外面的controller使用?
