electron-vue中報錯Cannot?use?import?statement?outside?a?module的解決方案(親測有效!)
錯誤:
Cannot use import statement outside a module(不能在模塊之外使用導(dǎo)入語句)。
原因:
安裝的某個依賴包里使用了import語法,因為我們打包輸出的是commonjs規(guī)范,所以不識別import語法而導(dǎo)致報錯。
可以從 .electron-vue/webpack.renderer.config.js目錄文件中看到如下一段代碼:
上面圖示中代碼就可以看出打包輸出的目標(biāo)文件為commonjs規(guī)范,對es2015規(guī)范中import語法不識別。
解決方案:
使用webpack中的externals配置項解決。示例如下:
externals作用:
防止將某些 import 的包(package)打包到 bundle 中,而是在運(yùn)行時(runtime)再去從外部獲取這些擴(kuò)展依賴(external dependencies)。
為什么使用了externals配置項可以解決:
因為在externals配置后,外部變量不會被打包,實際上可以以以下任何形式使用外部變量:全局變量、CommonJS、AMD、ES2015 模塊。此時就可以保證代碼在不同環(huán)境中可以識別import語法,從而不會有上面的報錯信息出現(xiàn)。
具體關(guān)于webpack配置中externals的傳送門:externals官方文檔 externalsType官方文檔
附:啟動項目exe文件后,發(fā)現(xiàn)無法調(diào)用出開發(fā)者工具
解決方式:a、在electron-vue主進(jìn)程中添加以下語句
mainWindow.webContents.openDevTools(); // 或者mainWindow.openDevTools();
b、將package.json 中的devDependencies(開發(fā)環(huán)境使用)這幾句添加到dependencies(生產(chǎn)環(huán)境使用),重新打包編譯后即可調(diào)用開發(fā)者工具。
"electron-debug": "^1.5.0", "electron-devtools-installer": "^2.2.4"
總結(jié)
到此這篇關(guān)于electron-vue中報錯Cannot use import statement outside a module的解決方案的文章就介紹到這了,更多相關(guān)報錯Cannot use import statement outside a module內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
vue +elementui 導(dǎo)入CSV文件的方式
封裝一個公共js方法,使用papaparse解析CSV文件且返回數(shù)組格式,下面通過示例代碼介紹vue +elementui 導(dǎo)入CSV文件的方式,感興趣的朋友一起看看吧2024-04-04詳解VS Code使用之Vue工程配置format代碼格式化
這篇文章主要介紹了詳解VS Code使用之Vue工程配置format代碼格式化,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2019-03-03