Luk*_*uke 5 node.js electron electron-builder
我在 Windows 中用 Electron 编写了一个小应用程序,并且有一些功能可以检查注册表以获取有关已安装的某些软件的信息,我需要在另一台机器上运行该应用程序进行测试。所以,我正在尝试打包我的应用程序。
首先,需要注意的是,当我>electron .在项目的根目录中运行时,它运行没有任何问题。
我尝试手动打包应用程序,将我的应用程序放在resources\app文件夹下并运行 Electron.exe。它不起作用。Electron 应用程序在退出之前在任务管理器中启动。没有任何错误或警告。没有对话框或任何东西。
我已经安装了电子打包器模块,并尝试使用它来打包应用程序。然而,它什么也不做。没有控制台输出,它只是在退出之前在那里停留了一段时间。当它退出时,没有打包的应用程序。什么也没有变。我尝试了电子制造商并得到了相同的结果。
我一般不熟悉节点,所以我怀疑我只是做错了什么。这是我的 package.json (我仍然不完全理解其目的):
{
"name": "welcome",
"version": "0.1.0",
"description": "",
"main": "main.js",
"scripts": {
"test": "echo \"Error: no test specified\" && exit 1",
"start": "electron .",
"compile": "node .\\node_modules\\webpack\\bin\\webpack.js",
"prep": "robocopy . releases\\app /XD node_modules releases blah /S /MIR /XF *.jsx \"webpack.config.js\" && robocopy node_modules\\winreg releases\\app && robocopy node_modules\\path releases\\app",
"package": "asar pack .\\releases\\app .\\releases\\app.asar",
"build": "electron-packager releases\\app WelcomeApp --ignore=node_modules --platform=win32 --arch=x64 --output=releases"
},
"author": "",
"license": "ISC",
"babel": {},
"dependencies": {
"electron": "^1.3.4",
"path": "^0.12.7",
"react": "^15.3.0",
"react-dom": "^15.3.0",
"winreg": "^1.2.1"
},
"devDependencies": {
"babel-core": "^6.13.1",
"babel-loader": "^6.2.4",
"babel-preset-es2015": "^6.13.1",
"babel-preset-react": "^6.11.1",
"electron-builder": "^5.34.1",
"electron-packager": "^7.7.0",
"webpack": "^1.13.1"
}
}
Run Code Online (Sandbox Code Playgroud)
我的目录结构如下
Welcome
|____app
| |____src
| | |____dist
| | | |____bundle.js
| | |____react
| | | |____components
| | | | |____installation.jsx
| | | | |____...
| | | | |____software.jsx
| | | |____index.jsx
| | |____util
| | |____data.js
| |____app.html
|____node_modules
| |____...
|____main.js
|____package.json
|____webpack.config.js
Run Code Online (Sandbox Code Playgroud)
从我所见,我正在做的事情没有问题。就像我说的,当使用电子 cli ( electron .)运行时,它工作得很好。所以,我不知所措。我只能假设 package.json 可能有问题。有问题吗?为什么我在运行打包程序时看不到任何控制台输出?
我将给您留下我如何使用电子打包器的 API 打包应用程序的脚本,也许您可以用它来构建您的.exe。
'use strict';
var packager = require('electron-packager');
var options = {
'arch': 'ia32',
'platform': 'win32',
'dir': './',
'app-copyright': 'Paulo Galdo',
'app-version': '2.1.6',
'asar': true,
'icon': './app.ico',
'name': 'TierraDesktop',
'out': './releases',
'overwrite': true,
'prune': true,
'version': '1.3.4',
'version-string': {
'CompanyName': 'Paulo Galdo',
'FileDescription': 'Tierra de colores', /*This is what display windows on task manager, shortcut and process*/
'OriginalFilename': 'TierraDesktop',
'ProductName': 'Tierra de colores',
'InternalName': 'TierraDesktop'
}
};
packager(options, function done_callback(err, appPaths) {
console.log("Error: ", err);
console.log("appPaths: ", appPaths);
});
Run Code Online (Sandbox Code Playgroud)
在这里您可以看到可以在此脚本上使用的所有选项:链接
| 归档时间: |
|
| 查看次数: |
5876 次 |
| 最近记录: |