把基于 node.js 的 web 应用打包成可执行客户端

2020-02-09 14:53:14 +08:00
 tanrunhao

最近发现一个项目可以把后端的 koa,express 之类的项目打包成可执行文件。 https://github.com/zeit/pkg

简单介绍打包过程和遇到的坑:

安装 pkg 模块

npm -i pkg -g

打包配置

由于 pkg 是分析依赖打包, 所以不会把静态和模板文件打包进去的。 需要修改 package.json 添加

"pkg": {
    "assets": [
      "views/*",
      "public/**/*"
    ]
  }

打包命令

pkg --out-path build  momo.js -c package.json

小问题, 由于网络问题,pkg 下载预编译的 node 老出错。 参考此issue

打包效果

启动程序后自动打开浏览器访问, 用 open模块 实现


最后是应用的使用截图

mac 双击会启动一个 terminal 框, 关闭此框即关闭程序。

由于是打包成可执行, 所以要改变之前部署配置的思路。

比如最近我写了个 mongodb 的数据查看工具, 本来 mongo 地址是写到配置文件, 然后部署的。

现在改成使用时候输入。

打开程序会访问登录页面, 为了方便使用, 会把 mongo 地址写到浏览器的缓存中

下次打开直接点击登录。 如果有更好更安全的办法请提供一下。

这是一个运行在本地的 web 应用, 使用方法就是双击一下。

这种打包运行的场景十分适合开发一些小工具给客户用的时候, 没必要动不动就搞个 electron。

6461 次点击
所在节点    Node.js
6 条回复
remon
2020-02-09 17:02:29 +08:00
需要分享给别人的小工具用 go 更爽
LokiSharp
2020-02-09 17:06:30 +08:00
然后看一下体积吓死人。。。
zzzzzzk
2020-02-09 17:08:08 +08:00
electron 不也可以吗
tanrunhao
2020-02-09 17:19:20 +08:00
@zzzzzzk 可以, 不过你的项目一开始是按 web 应用写的。 改成 electron 就没那么简单了。
tanrunhao
2020-02-09 17:22:25 +08:00
@remon go,rust 这种肯定爽。 前提是会写啊 😂
ArrayBuffer
2020-03-17 08:21:29 +08:00
引入了原生模块阔以打包吗

这是一个专为移动设备优化的页面(即为了让你能够在 Google 搜索结果里秒开这个页面),如果你希望参与 V2EX 社区的讨论,你可以继续到 V2EX 上打开本讨论主题的完整版本。

https://www.v2ex.com/t/643215

V2EX 是创意工作者们的社区,是一个分享自己正在做的有趣事物、交流想法,可以遇见新朋友甚至新机会的地方。

V2EX is a community of developers, designers and creative people.

© 2021 V2EX