electron打包中的巨坑解決記錄
吐槽
從上周五到今天,我被electron打包折磨得死去活來,本來想讓測試用桌面端的,現(xiàn)在不得不改用web端,真的好無語。今天解決問題順利打包后來記錄一下這個問題。
問題一:css文件中圖片加載失敗
問題描述
問題是這樣的,electron打包為桌面端以后,登錄頁的表單是正常顯示的,但是整個頁面的背景圖沒了。我百度了一下,發(fā)現(xiàn)大多是說白屏啥的,但是我不是白屏啊,我的表單能正常顯示,為此,我在生產(chǎn)環(huán)境打開了調(diào)試工具:
createProtocol('app')
// Load the index.html when not in development
win.loadURL('app://./index.html')
win.webContents.openDevTools()
發(fā)現(xiàn)原來是我的css文件中的圖片路徑錯了:

到底錯在哪兒?隨意看看一份正常加載的js文件就知道了:

原來是app://./ 開頭而不是 app://,真的是大冤種轉(zhuǎn)世了! 我發(fā)現(xiàn)此問題只存在于css文件中的background:url()這樣的代碼里,項目使用的是vue-cli腳手架,也就是使用的webpack,我在這已經(jīng)知道大致是某些loader和plugin處理時造成的bug了。
解決過程
竟然知道了是loader和plugin的鍋,剛開始我嘗試自已寫一個loader,只要通過一行正則表達(dá)式大概就能解決問題了:
const res= content.replace(/app:\/\/\//,"app://./");
//app-loader
module.exports = function (content) {
return content.replace(/app:\/\/\//, "app://./");
}
但我失敗了。 原因在于我匹配了css文件,但是vue-cli腳手架已經(jīng)為css文件的處理內(nèi)置了許多的loader,我們可以通過 vue inspect查看實際的webpack配置來觀察loader情況
vue inspect --mode production >> webpack.test.js

其依次使用了postcss-loader、css-loader和extract-css-loader,那么,我們將自定義的app-loader放在extract-css-loader之前不就好了(注意webpack中的loader執(zhí)行順序從右到左), 通過chainWebpack這項vue-cli提供的鏈?zhǔn)脚渲茫▽嶋H封裝了webapck-chain這個插件)來將我們的loader加入。
if (IS_PROD) {
config.resolveLoader.modules.add("./src/loaders");
config.module.rule('css').oneOf('vue-modules').use('app-loader').before('extract-css-loader').loader('app-loader')
}

然而經(jīng)過打包后我又失敗了,依然是app:/// 這樣的路徑。
到底為什么?
原因在于extract-css-loader是由mini-extract-css-plugin提供的,而熟悉它的小伙伴們都知道,這兩個是配套使用的,因此,當(dāng)我嘗試在我的loader中輸出文件內(nèi)容時,我將得到如下信息:
我不得不懷疑實際修改代碼,劃分chunks的操作是在該plugin中完成的,看來還是寫一個plugin來處理吧! 但當(dāng)前我來不及閱讀mini-extract-css-plugin的源碼了,我只能想到在插件的hooks中找到一個合適的時機(jī)去處理已經(jīng)被處理轉(zhuǎn)換的代碼,最終我選擇了emit這個hook。 處理代碼如下:
compiler.hooks.emit.tap('AppPlugin', (compilation) => {
compilation.assetsInfo.forEach((assetsItem, key) => {
if (/\.css$/.test(key) && !/^static\/lib\//.test(key)) {
compilation.assets[key]._value = compilation.assets[key]._value.replace(/app:\/\/\//g, "app://./")
}
})
})
這段代碼解釋起來就是compilation中的assets存放著所有的之前處理后的代碼,由于使用了emit 這個hook,也就是即將被webpack輸出的代碼,通過遍歷assetsInfo(相當(dāng)于assets這個對象里的代碼清單,key是即將輸出的相對路徑),只要判斷其所有的css文件,將 _value 也就是要處理代碼使用正則替換就可以了(為什么知道是它?調(diào)試時不斷打印發(fā)現(xiàn)的)。
經(jīng)過驗證,該方法可行。
補(bǔ)充
此部分需要有一定的webpack基礎(chǔ),我也是不停查閱官方文檔和不停百度了解了一些屬性和配置,如何手寫loader和plugin的帖子很多,我就不做搬運(yùn)了。
問題二:無法使用cookie
問題描述
當(dāng)我登錄頁面登錄后發(fā)現(xiàn)登錄失敗,任由我怎么登錄都是停留在登錄頁面。
原因分析
這個問題還是比較容易解釋的,畢竟我用了app://這樣的協(xié)議,不是web端上的http:// 這樣的,cookie就掛了。然后嘛,我的路由守衛(wèi)由于無法訪問cookie獲取到token就一直停留在登錄頁面。 正確的做法就是改用sessionStorage或者localStorage來存儲token。
總結(jié)
electron確實太坑了,只要足夠有耐心問題最終也能順利解決,多看文檔多調(diào)試就是了。大家還碰上哪些electron的坑呢?
以上就是electron打包中的巨坑解決記錄的詳細(xì)內(nèi)容,更多關(guān)于electron打包坑解決的資料請關(guān)注腳本之家其它相關(guān)文章!
相關(guān)文章
Vue通過字符串關(guān)鍵字符實現(xiàn)動態(tài)渲染input輸入框
這篇文章主要為大家詳細(xì)介紹了Vue如何通過字符串關(guān)鍵字符實現(xiàn)動態(tài)渲染input輸入框。文中的示例代碼講解詳細(xì),感興趣的小伙伴可以了解一下2022-12-12
如何利用vue-cli監(jiān)測webpack打包與啟動時長
這篇文章主要給大家介紹了關(guān)于如何利用vue-cli監(jiān)測webpack打包與啟動時長的相關(guān)資料,文中通過實例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友可以參考下2022-02-02
Vue3使用路由及配置vite.alias簡化導(dǎo)入寫法的過程詳解
這篇文章主要介紹了Vue3使用路由及配置vite.alias簡化導(dǎo)入寫法,本文通過實例代碼給大家講解的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下2022-11-11
vue element實現(xiàn)將表格單行數(shù)據(jù)導(dǎo)出為excel格式流程詳解
這篇文章主要介紹了vue element實現(xiàn)將表格單行數(shù)據(jù)導(dǎo)出為excel格式流程,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)吧2022-12-12
使用Vue.js報錯:ReferenceError: “Vue is not d
在前端開發(fā)中,ReferenceError: "Vue is not defined" 是一個常見的錯誤,該錯誤通常發(fā)生在項目中未正確引入 Vue.js 框架或代碼配置存在問題時,本篇文章將詳細(xì)分析該錯誤的成因,并提供多種解決方案,幫助開發(fā)者快速排查問題,需要的朋友可以參考下2024-12-12
vue登錄以及權(quán)限驗證相關(guān)的實現(xiàn)
這篇文章主要介紹了vue登錄以及權(quán)限驗證相關(guān)的實現(xiàn),文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2019-10-10
Vuepress生成文檔部署到gitee.io的注意事項及說明
這篇文章主要介紹了Vuepress生成文檔部署到gitee.io的注意事項及說明,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2022-09-09
vue實現(xiàn)導(dǎo)出excel的多種方式總結(jié)
在Vue中實現(xiàn)導(dǎo)出Excel有多種方式,可以通過前端實現(xiàn),也可以通過前后端配合實現(xiàn),這篇文章將為大家詳細(xì)介紹幾種常用的實現(xiàn)方式,需要的可以參考下2023-08-08

