javascript - js中單例模式疑惑
問(wèn)題描述
以下代碼
function Universe() { // 緩存的實(shí)例 var instance = this; // 其它內(nèi)容 this.start_time = 0; this.bang = 'Big'; // 重寫(xiě)構(gòu)造函數(shù) Universe = function () {return instance; };}// 測(cè)試var uni = new Universe();var uni2 = new Universe();uni.bang = '123';console.log(uni === uni2); // trueconsole.log(uni2.bang); // 123
點(diǎn)擊查看原文
問(wèn)題:
new Universe()的過(guò)程是:var o = {};Universe.call(o);//這一步是將Universe中this對(duì)應(yīng)的屬性賦值給o;o.__proto__ = Universe.prototype;//將Universe原型上的方法賦值到o的__proto__屬性上;
那么 var instance = this;中,this是不是指的是不同的對(duì)象o?那么重寫(xiě)構(gòu)造函數(shù)后,返回的instance不就是不同的對(duì)象嗎?為什么最后能相等
問(wèn)題解答
回答1:因?yàn)橹貙?xiě)了構(gòu)造函數(shù)后, 返回一個(gè)對(duì)象, 這個(gè)對(duì)象會(huì)覆蓋你 用new 構(gòu)造函數(shù)生成的那個(gè)對(duì)象,不知道我有沒(méi)有說(shuō)清楚
回答2:@mpccc 說(shuō)的對(duì)。
如果構(gòu)造函數(shù)返回一個(gè)對(duì)象,那 new 出來(lái)的就是這個(gè)對(duì)象啦。
可以看看秘密花園中的構(gòu)造函數(shù)這一段
回答3:我也是新手,嘗試解答一下,要是錯(cuò)了可別怪我
第一 this是不是指的是不同的對(duì)象 在第一次調(diào)用構(gòu)造函數(shù)的時(shí)候 產(chǎn)生一個(gè)空的對(duì)象 并且函數(shù)內(nèi)部的this指向了這個(gè)空對(duì)象,接著執(zhí)行代碼,最后返回這個(gè)對(duì)象 也就是uni。
而在第二次調(diào)用的時(shí)候由于第一次函數(shù)的改寫(xiě),產(chǎn)生了一個(gè)閉包,這個(gè)閉包的內(nèi)部的instance正好指向了第一次調(diào)用時(shí)的產(chǎn)生的對(duì)象uni,當(dāng)?shù)诙螆?zhí)行new Universe()的時(shí)候你執(zhí)行的是一個(gè)閉包,也會(huì)產(chǎn)生一個(gè)空的對(duì)象,但那個(gè)對(duì)象并沒(méi)有用到它,反而是直接返回了閉包內(nèi)部的instance也就是uni。
所以u(píng)ni2 === uni.
回答4:偏個(gè)題,這樣寫(xiě)單例模式有點(diǎn)多余,要?jiǎng)?chuàng)建唯一的對(duì)象不用非得造個(gè)構(gòu)造函數(shù)
var single = function(fn){ var instance; return function(){ return instance || (instance = fn .apply(this, arguments)); } }; 回答5:
不是注釋寫(xiě)了嗎,重寫(xiě)了構(gòu)造函數(shù)啊,你new了一次之后再new就沒(méi)有var instance = this;這行代碼了,instance自然就不變了
//簡(jiǎn)單打印一下就知道了console.log(Universe)var uni = new Universe()console.log(Universe)回答6:
首次執(zhí)行new Universe()的時(shí)候,確實(shí)產(chǎn)生了一個(gè)新的this,并且將Universe構(gòu)造函數(shù)改寫(xiě)了,之后再次調(diào)用這個(gè)new Universe()的時(shí)候,就只會(huì)return instance了,不會(huì)產(chǎn)生新的對(duì)象了。
相關(guān)文章:
1. 求救一下,用新版的phpstudy,數(shù)據(jù)庫(kù)過(guò)段時(shí)間會(huì)消失是什么情況?2. mysql - 如何在有自增id的情況下,讓其他某些字段能不重復(fù)插入3. django - Python error: [Errno 99] Cannot assign requested address4. python小白 關(guān)于類(lèi)里面的方法獲取變量失敗的問(wèn)題5. angular.js - 百度支持_escaped_fragment_嗎?6. Python2中code.co_kwonlyargcount的等效寫(xiě)法7. [python2]local variable referenced before assignment問(wèn)題8. node.js - win 下 npm install 遇到了如下錯(cuò)誤 會(huì)導(dǎo)致 無(wú)法 run dev么?9. python小白,關(guān)于函數(shù)問(wèn)題10. javascript - webpack1和webpack2有什么區(qū)別?
