电子封装后不支持ES6 [英] ES6 is not supported after Electron packaging

查看:91
本文介绍了电子封装后不支持ES6的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!

问题描述

我正在使用各种 ES6语法(例如 import 等)和反应代码( JSX )在基于 Electron 的应用程序中。在开发过程中,我使用了 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 软件包并运行可分发的应用程序文件,我遇到了不受支持的ES6相关问题错误,例如:

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

这就是我运行电子包装程序命令的方式(注意平台和体系结构标志):

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

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

我的打包/可分发版本的任何原因应用程序不支持ES6 / React功能?

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

推荐答案

已解决。

事实证明,默认情况下在打包过程中会省略 devDependencies ,这意味着 electron-prebuild-compile 软件包不在游戏中,对于打包的应用程序,没有它,ES6无法反编译。因此,为了停用此默认行为,我必须使用-no-prune 标志调用packager命令,以便保留 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

此外,我有引入新脚本(将其命名为: es6-init.js )以初始化主应用程序的脚本,以便在呈现之前编译代码(应该是用作应用程序的主要入口点脚本):

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

这篇关于电子封装后不支持ES6的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持IT屋!

查看全文
登录 关闭
扫码关注1秒登录
发送“验证码”获取 | 15天全站免登陆