文章詳情頁
javascript - 兩個js文件相互require
瀏覽:182日期:2023-04-29 18:26:16
問題描述
今天遇到的筆試題,請各位老鐵解惑a.js和b.js相互require,會不會陷入死循環?能不能導出結果?怎么避免這一問題?
問題解答
回答1:這是考察JavaScript模塊的循環加載你可以用使用es6的模塊機制繞開這個問題,ES6處理'循環加載'與CommonJS有本質的不同。ES6根本不會關心是否發生了'循環加載',只是生成一個指向被加載模塊的引用,需要開發者自己保證,真正取值的時候能夠取到值。
回答2:如果從字面意思理解,只使用
var b = require(’b’)
那么這個問題可以理解成CommonJS中的循環引用問題。CommonJS的做法是,一旦出現某個模塊被'循環加載',就只輸出已經執行的部分,還未執行的部分不會輸出。
如果從概念上理解兩個模塊之間的循環引用,則還涉及到es6的模塊引用。
import b from ’b’
ES6根本不會關心是否發生了'循環加載',只是生成一個指向被加載模塊的引用,需要開發者自己保證,真正取值的時候能夠取到值。
單純只使用CommonJs,或者單純只使用esm(es6 module),都不會發生死循環。但如果兩者混用就可能會發生。
推薦阮一峰的一篇博客,寫得挺完善的。http://www.ruanyifeng.com/blo...
標簽:
JavaScript
相關文章:
1. javascript - 在靜態頁面上用load 引入的頁面文件問題?2. javascript - webpack打包后的bundlejs文件代碼不知道什么意思.3. android - RxJavar用什么操作符可以使數據每隔一段時間取出一個4. Android的webView如何實現網頁 錄音功能?5. java - oracle對漢字字段按照拼音排序的函數和sql語句是什么?6. css - 關于ul的布局7. css - 如何使用 vue transition 實現 ios 按鈕一樣的平滑切換效果8. Java游戲服務器開發和網站、app服務端的開發都差不多的嗎???實現的思路和方法9. javascript - vue組件通過eventBus通信時,報錯a.$on is not a function10. html - 哪些情況下float會失效?
排行榜
