javascript - 兩個(gè)js文件相互require
問(wèn)題描述
今天遇到的筆試題,請(qǐng)各位老鐵解惑a.js和b.js相互require,會(huì)不會(huì)陷入死循環(huán)?能不能導(dǎo)出結(jié)果?怎么避免這一問(wèn)題?
問(wèn)題解答
回答1:這是考察JavaScript模塊的循環(huán)加載你可以用使用es6的模塊機(jī)制繞開這個(gè)問(wèn)題,ES6處理'循環(huán)加載'與CommonJS有本質(zhì)的不同。ES6根本不會(huì)關(guān)心是否發(fā)生了'循環(huán)加載',只是生成一個(gè)指向被加載模塊的引用,需要開發(fā)者自己保證,真正取值的時(shí)候能夠取到值。
回答2:如果從字面意思理解,只使用
var b = require(’b’)
那么這個(gè)問(wèn)題可以理解成CommonJS中的循環(huán)引用問(wèn)題。CommonJS的做法是,一旦出現(xiàn)某個(gè)模塊被'循環(huán)加載',就只輸出已經(jīng)執(zhí)行的部分,還未執(zhí)行的部分不會(huì)輸出。
如果從概念上理解兩個(gè)模塊之間的循環(huán)引用,則還涉及到es6的模塊引用。
import b from ’b’
ES6根本不會(huì)關(guān)心是否發(fā)生了'循環(huán)加載',只是生成一個(gè)指向被加載模塊的引用,需要開發(fā)者自己保證,真正取值的時(shí)候能夠取到值。
單純只使用CommonJs,或者單純只使用esm(es6 module),都不會(huì)發(fā)生死循環(huán)。但如果兩者混用就可能會(huì)發(fā)生。
推薦阮一峰的一篇博客,寫得挺完善的。http://www.ruanyifeng.com/blo...
相關(guān)文章:
1. 為什么我ping不通我的docker容器呢???2. 關(guān)于docker下的nginx壓力測(cè)試3. webpack - vuejs+java前后臺(tái)分離實(shí)現(xiàn)及部署問(wèn)題4. tp6中env::get相關(guān)問(wèn)題5. 管理員添加問(wèn)題6. mysql - 多表關(guān)聯(lián)查詢的實(shí)現(xiàn)方法?7. mysql優(yōu)化 - mysql innodb 與 myisam 鎖8. php - TP5的登錄驗(yàn)證問(wèn)題9. 網(wǎng)站在移動(dòng)的環(huán)境下手機(jī),pc打不開10. PHP搜索代碼只能搜出一頁(yè),點(diǎn)擊任意頁(yè)碼不實(shí)現(xiàn)
