javascript工廠(chǎng)函數(shù)實(shí)戰(zhàn)項(xiàng)目——12個(gè)模塊引用同一份js

最近在做一個(gè)后管項(xiàng)目胖翰,其中有一個(gè)功能有多個(gè)類(lèi)似的模塊,前端項(xiàng)目新建了12個(gè)html頁(yè)面帕膜,頁(yè)面ID不同,前端根據(jù)ID作為12個(gè)頁(yè)面的區(qū)分溢十。之前的做法是一個(gè)html對(duì)應(yīng)一個(gè)js垮刹,這樣保證頁(yè)面之間的數(shù)據(jù)不會(huì)串聯(lián),這次挑戰(zhàn)一下张弛,12個(gè)頁(yè)面復(fù)用一個(gè)js文件:

思考點(diǎn):如何做到頁(yè)面之間的數(shù)據(jù)不會(huì)發(fā)生交叉荒典,即后面的數(shù)據(jù)覆蓋之前的數(shù)據(jù)?

答案是:作用域吞鸭。每個(gè)頁(yè)面模塊擁有了自己的作用域寺董,彼此互相獨(dú)立。

具體做法:

1刻剥、js文件創(chuàng)建一個(gè)工廠(chǎng)函數(shù)

function init (opts) {

? ? this.wrap = opts.wrap;

? ? this.name = opts.name;

? ? ...

}

init.prototype.fn1 = function () {

}

init.prototype.fn2 = function () {

}

return init

2遮咖、在12個(gè)頁(yè)面里面引用這個(gè)js

var pa1? = new init ({name: name, wrap: wrap});

pa1();

var pa2? = new init ({name: name, wrap: wrap});

pa2();

此時(shí)new出一個(gè)實(shí)例pa1. pa2,它們都擁有了一個(gè)獨(dú)立的作用域透敌,并且繼承了init的原型方法和屬性盯滚。

new 做了3件事情

1、創(chuàng)建一個(gè)空對(duì)象? var obj = {}

2酗电、把這個(gè)空對(duì)象的原型鏈指向 構(gòu)造函數(shù) obj.__proto__ = init.prototype;

3魄藕、具體執(zhí)行構(gòu)造函數(shù)并把this綁定到這個(gè)空對(duì)象{}。init.call(obj, name, wrap);? 返回這個(gè)實(shí)例對(duì)象

用代碼說(shuō)話(huà):


最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末撵术,一起剝皮案震驚了整個(gè)濱河市背率,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌嫩与,老刑警劉巖寝姿,帶你破解...
    沈念sama閱讀 217,826評(píng)論 6 506
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場(chǎng)離奇詭異划滋,居然都是意外死亡饵筑,警方通過(guò)查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,968評(píng)論 3 395
  • 文/潘曉璐 我一進(jìn)店門(mén)处坪,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái)根资,“玉大人,你說(shuō)我怎么就攤上這事同窘⌒粒” “怎么了?”我有些...
    開(kāi)封第一講書(shū)人閱讀 164,234評(píng)論 0 354
  • 文/不壞的土叔 我叫張陵想邦,是天一觀(guān)的道長(zhǎng)裤纹。 經(jīng)常有香客問(wèn)我,道長(zhǎng)丧没,這世上最難降的妖魔是什么鹰椒? 我笑而不...
    開(kāi)封第一講書(shū)人閱讀 58,562評(píng)論 1 293
  • 正文 為了忘掉前任锡移,我火速辦了婚禮,結(jié)果婚禮上吹零,老公的妹妹穿的比我還像新娘罩抗。我一直安慰自己,他們只是感情好灿椅,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,611評(píng)論 6 392
  • 文/花漫 我一把揭開(kāi)白布套蒂。 她就那樣靜靜地躺著,像睡著了一般茫蛹。 火紅的嫁衣襯著肌膚如雪操刀。 梳的紋絲不亂的頭發(fā)上,一...
    開(kāi)封第一講書(shū)人閱讀 51,482評(píng)論 1 302
  • 那天婴洼,我揣著相機(jī)與錄音骨坑,去河邊找鬼。 笑死柬采,一個(gè)胖子當(dāng)著我的面吹牛欢唾,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播粉捻,決...
    沈念sama閱讀 40,271評(píng)論 3 418
  • 文/蒼蘭香墨 我猛地睜開(kāi)眼礁遣,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼!你這毒婦竟也來(lái)了肩刃?” 一聲冷哼從身側(cè)響起祟霍,我...
    開(kāi)封第一講書(shū)人閱讀 39,166評(píng)論 0 276
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤,失蹤者是張志新(化名)和其女友劉穎盈包,沒(méi)想到半個(gè)月后沸呐,有當(dāng)?shù)厝嗽跇?shù)林里發(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 45,608評(píng)論 1 314
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡呢燥,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,814評(píng)論 3 336
  • 正文 我和宋清朗相戀三年崭添,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片叛氨。...
    茶點(diǎn)故事閱讀 39,926評(píng)論 1 348
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡滥朱,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出力试,到底是詐尸還是另有隱情,我是刑警寧澤排嫌,帶...
    沈念sama閱讀 35,644評(píng)論 5 346
  • 正文 年R本政府宣布畸裳,位于F島的核電站,受9級(jí)特大地震影響淳地,放射性物質(zhì)發(fā)生泄漏怖糊。R本人自食惡果不足惜帅容,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,249評(píng)論 3 329
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望伍伤。 院中可真熱鬧并徘,春花似錦、人聲如沸扰魂。這莊子的主人今日做“春日...
    開(kāi)封第一講書(shū)人閱讀 31,866評(píng)論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)劝评。三九已至姐直,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間蒋畜,已是汗流浹背声畏。 一陣腳步聲響...
    開(kāi)封第一講書(shū)人閱讀 32,991評(píng)論 1 269
  • 我被黑心中介騙來(lái)泰國(guó)打工, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留姻成,地道東北人插龄。 一個(gè)月前我還...
    沈念sama閱讀 48,063評(píng)論 3 370
  • 正文 我出身青樓,卻偏偏與公主長(zhǎng)得像科展,于是被迫代替她去往敵國(guó)和親均牢。 傳聞我的和親對(duì)象是個(gè)殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 44,871評(píng)論 2 354