这有什么用呢?
我呢,就是为了演示 web 界面(+ 仿真数据),又不想依赖于 node 。。。等一系列的前端环境
这个工具,直接会生成一个 exe 文件,双击即可运行我们的 node 程序
如何使用,可参考以下两篇文章
简单说说呢
第一步,先安装 Pkg
npm install -g pkg
安装完后,可以通过 pkg -h 查看相关命令
第二步, 尝试运行
pkg api.js // 将 api.js 编译成 api.exe 可执行文件
pkg -t win api.js // 上面的命令会同时编译出 linux 、windows 、mac 版的 exe,加 -t win 就可以只编译 windows 下的
这时,可能会有部分同学遇到问题, 报错了!!!
> pkg@4.4.0
> Fetching base Node.js binaries to PKG_CACHE_PATH
fetched-v10.15.3-win-x64 [ ] 0%
> Error! connect ETIMEDOUT 13.229.188.59:443
> Asset not found by direct link:
{"tag":"v2.6","name":"uploaded-v2.6-node-v10.15.3-win-x64"}
如何解决?
到 github.com/zeit/pkg-fe… 下载对应 node 版本的包(比如,我下的就是 uploaded-v2.6-node-v10.15.3-win-x64)
然后复制粘贴到 C:\Users\aaa\.pkg-cache\v2.6 这个目录下,重命名(我的就重命名为 fetched-v10.15.3-win-x64),同时将这个目录下的 .downloading 结尾的文件删除了
重新输入命令,嗯,生成对应的 .exe 文件了,双击该文件,与我们直接运行 node api.js 的效果是一样的
同理,如果想要在编译 linux 版本的的话,就把对应的 node 包,名字修改为 fetch-vXX.XX.X-linux-x64 即可
其他打包方式
pkg 可以根据 package.json 下的配置进行打包
// 以 express 为例
// bin 对应的 express 的入口文件,即 输入 node api.js,即可运行我的 express 代码(这个版本有点旧,新的话好像是 bin/www)
// assets 对应的是 express.static 下的静态文件目录
{
"bin": "api.js",
"pkg": {
"assets": [
"dist/**/*" //静态文件的目录,可添加多个
]
}
}
此时运行 pkg -t win . 即可根据 package.json 进行编译
点击 .exe,可能还有问题
点击 .exe,发现有些接口返回 404 Not Found
例如下例,将 exe 放到其他文件下,尝试打开页面,发现报 Can't get /
app.use('/', express.static('dist'));
因为 pkg 没有把这些文件给打包进去,他只会打包使用 require 或者 通过 __filename 和 __dirname 的文件
所以需要修改为
app.use('/', express.static(path.join(__dirname, 'dist')));
其他注意项
如果有些配置文件,不想被打包进 exe 文件中,而是想把部分配置文件放在外面可被修改,则可以使用 process.cwd() 来引用文件
const port = require(process.cwd() + '/port');
// 不过编译的时候,pkg 有告警提示
Dynamic require may fail at run time, because the requested file
is unknown at compilation time and not included into executable.
Use a string literal as an argument for 'require', or leave it
as is and specify the resolved file name in 'scripts' option.
process.cwd() 和 __diranme 的区别可以参考这文章: process.cwd()和__dirname的区别