久久久久久久av_日韩在线中文_看一级毛片视频_日本精品二区_成人深夜福利视频_武道仙尊动漫在线观看

Electron 打包后不支持 ES6

ES6 is not supported after Electron packaging(Electron 打包后不支持 ES6)
本文介紹了Electron 打包后不支持 ES6的處理方法,對大家解決問題具有一定的參考價值,需要的朋友們下面隨著小編來一起學習吧!

問題描述

我正在使用各種 ES6 語法(例如 import 等)&React 代碼 (JSX) 在我的基于 Electron 的應用程序中.在開發(fā)過程中,我使用 electron-prebuilt-compile 包(作為 dev-dependency) 以支持這些新功能,它工作得非常好,沒有任何錯誤.

I'm using various ES6 syntax (such as import etc.) & React code (JSX) in my Electron-based application. During the development, I'm using the electron-prebuilt-compile package (as a dev-dependency) in order to support these new features and it works perfectly fine without any errors.

但是在使用 electron-packager 包打包我的應用程序并運行可分發(fā)包之后應用程序文件,我遇到了不受支持的 ES6 相關(guān)錯誤,例如:

But after packaging my app using the electron-packager package and running the distributable application file, I experiencing unsupported ES6-related errors such as:

Unexpected token import

這就是我運行電子打包程序命令的方式(注意平臺和架構(gòu)標志):

That's is how I run the electron-packager command (notice to the platform & architecture flags):

electron-packager . MyCoolApp --platform=linux --arch=x64

我的應用程序的打包/可分發(fā)版本不支持 ES6/React 功能的任何原因?

Any reason why a packaged/distributable version of my application does not support ES6/React features?

推薦答案

已解決.

事實證明 devDependencies 在打包過程中默認被省略,這意味著 electron-prebuild-compile 包對于打包的應用程序和沒有它 ES6 不能被轉(zhuǎn)譯.因此,為了停用此默認行為,我必須使用 --no-prune 標志調(diào)用打包程序命令,以便 devDependencies 將保留而不會被刪除:

it turns out that devDependencies are being omitted during packaging by default, which means that the electron-prebuild-compile package is "out of the game" for a packaged application and without it ES6 can't be transcompiled. So in order to deactivate this default behavior, I had to call the packager command with the --no-prune flag so that the devDependencies will remain without being deleted:

electron-packager . MyCoolApp --platform=linux --arch=x64 --no-prune

此外,為了在渲染之前編譯"代碼(它應用作應用程序的主要入口點腳本):

In addition, I had to introduce a new script (let's name it: es6-init.js) for initialization of the main app's script in order to "compile" the code before rendering (it should be used as the main entry point script of your application):

var appRoot = path.join(__dirname, '..');

require('electron-compile').init(appRoot, require.resolve('./main'));

參考資料:

  • https://github.com/electron-userland/electron-compile#how-does-it-work-slightly-harder-way
  • https://github.com/electron-userland/electron-packager

這篇關(guān)于Electron 打包后不支持 ES6的文章就介紹到這了,希望我們推薦的答案對大家有所幫助,也希望大家多多支持html5模板網(wǎng)!

【網(wǎng)站聲明】本站部分內(nèi)容來源于互聯(lián)網(wǎng),旨在幫助大家更快的解決問題,如果有圖片或者內(nèi)容侵犯了您的權(quán)益,請聯(lián)系我們刪除處理,感謝您的支持!

相關(guān)文檔推薦

How to fix BrowserWindow is not a constructor error when creating child window in Electron renderer process(在 Electron 渲染器進程中創(chuàng)建子窗口時如何修復 BrowserWindow 不是構(gòu)造函數(shù)錯誤) - IT屋-程序員軟件開發(fā)技術(shù)
mainWindow.loadURL(quot;https://localhost:3000/quot;) show white screen on Electron app(mainWindow.loadURL(https://localhost:3000/) 在 Electron 應用程序上顯示白屏)
Electron webContents executeJavaScript : Cannot execute script on second on loadURL(Electron webContents executeJavaScript:無法在第二個 loadURL 上執(zhí)行腳本)
how to use electron browser window inside components in angular-cli?(如何在angular-cli的組件內(nèi)使用電子瀏覽器窗口?)
ElectronJS - sharing redux store between windows?(ElectronJS - 在 Windows 之間共享 redux 存儲?)
How to access camera/webcamera inside electron app?(如何在電子應用程序中訪問相機/網(wǎng)絡攝像頭?)
主站蜘蛛池模板: 97色伦网| 欧美操操操 | 欧美一级黄色片 | 国产亚洲一区二区三区在线观看 | 色欧美片视频在线观看 | 91精品国产综合久久久久蜜臀 | 91色视频在线 | 亚洲成人国产精品 | 99re视频在线观看 | 日韩中文字幕久久 | 免费国产视频在线观看 | 超碰97免费在线 | 91玖玖 | 999久久精品 | 久久久免费电影 | 一区二区亚洲 | 国产一区二区三区日韩 | 国产婷婷在线视频 | 激情亚洲 | 超碰激情 | 99久久免费精品国产免费高清 | 中文字幕成人在线 | 国产九九九九 | 国产高清精品一区二区三区 | 欧美日产国产成人免费图片 | 草久在线视频 | 天天躁日日躁狠狠的躁天龙影院 | 日本成人午夜影院 | 欧美激情免费在线 | 99久视频 | 波多野结衣一区二区三区在线观看 | 欧美日韩一区二区三区四区 | 欧美日韩亚洲三区 | 拍真实国产伦偷精品 | 亚洲91| 欧美一级免费看 | 久久精品免费观看 | 一区二区三区福利视频 | 成人福利视频 | 国产乱码精品1区2区3区 | 欧美日韩国产一区二区三区 |