angular打包(三):pkg
希望打包成1个web服务,运行exe,启动 angular,供浏览器显示。
问题分析:
其实angular编译后,都是静态文件了。只需要打包express,让express可以以exe的形式运行就可以了。
pkg的坑很多,写下来。
1 打包配置
这部分最坑。官网说的也不太清楚,绕了很多弯路。
我的最终做法如下:
1 在ng工程下单独建1个文件夹 命名为pkg(随便)
2 在pkg里建立package.json:
{
"name": "frontend",
"bin": "server.js",
"dependencies": {
"express": "4.17.1"
},
"pkg": {
"assets": ["../dist/**/*"]
}
}
说明:
1 只需要打包express作为静态文件服务器。
用于伺服ng build 之后的dist文件夹即可,而不是把整个ng工程都打包。
因为ng是前端,只是在开发过程中用npm/node 进行包管理,而不是用node写的后端服务。
——一开始没想清这个,也确实发现pkg的问题:无法正确打包normalize.css 库, 然后才发现,我其实根本不需要打包这个。
2 dist文件夹全部当做assets处理。
即默认的ng编译出的文件位置。ng已经对文件进行了编译(--aot)。
3 建立server.js
const express = require('express');
const app = express();
const path = require('path');
const path_dist = path.join(path.resolve(__dirname, '..'), 'dist')
app.use(express.static(path_dist));
app.get('/*', (req, res) => {
res.sendFile(path.join(path_dist, 'index.html'));
});
var server = app.listen(4000, function () {
var host = server.address().address
var port = server.address().port
console.log(`server start successfully on http://${host}:${port}`)
})
说明:
1 静态文件指向外层dist文件夹
2 express 路由 写成/*, 保证直接访问任意host:port/XX/YY 这样的url时,都能正确处理。
express 只负责把任意路由都指向 index.html就够了,
ng居然后面能自动正确处理路由。
这一点还是很智能,很省心的。
2 用pkg打包
win+R cmd, cd到包含server.js和package.json的路径下 执行
pkg server.js -t win-x64 --config package.json
坑点1:必须显式指定 --config ,否则只会孤零零打包server.js一个文件。
启动服务后,如果是简单hello world会正确,但是ng工程 浏览器会提示
cannot GET /
因为根没用package.json,所以dist根本就没打包进来
坑点2:打包时,会首先下载一个pkg专用的node 二进制文件, 40M左右,发布的打包exe就是基于这个的。不同平台,不同node版本不同。好像只支持node长期版,比如10 12这样的。
但是国内网不好,下载很慢,甚至总是中断。
尝试每天不同时段下载试试,反正不下载好这个,是根本无从打包的。
下载位置:
C:\Users\用户名\.pkg-cache
v2.6 文件夹 是 pkg@4.4.0 用的 比如给windos 和 node12用的 就是 fetched-v12.2.0-win-x64
2.5 是 之前的版本
一旦下载好后:可以保存起来,复制到别的机器上,避免再次下载。
—— 最终打包成功后exe的体积约等于 下载的40M二进制文件 + dist文件夹的体积。
------------------------后记-----------------------------
用pkg打包坑点太多。 搜索了不少文章,但是误导,含混居多。包括官方文档,也不是太清楚。所以我就不列出引用了。
但是最终打包出来还是很小巧可人的。
总是打包失败的时候,我一度想直接用py的flask+ cxfreeze打包算了。那样必然体积大些。
现在这样很好。又学会1招。
angular打包(三):pkg的更多相关文章
- Mac Angular打包报错xcode-select: error: tool 'xcodebuild' requires Xcode
Mac Angular打包报错: Error: xcode-select: error: tool 'xcodebuild' requires Xcode, but active developer ...
- Angular总结三:组件
Angular 的应用就是一棵组件树,一个页面可以是一个组件,某一页面的一个区块也可以是一个组件.为了弄明白组件及组件树,我将原来做过的一个静态网站进行组件改造. 原项目地址 https://gith ...
- angular打包(一): electron
路由问题: 打包成electron前,需要修改 index.html <base href="/"> 成 <base href="./"> ...
- 从零开始一个个人博客 by asp.net core and angular(三)
这是第三篇了,第一篇只是介绍,第二篇介绍了api项目的运行和启动,如果api项目没什么问题了,调试都正常了,那基本上就没什么事了,由于这一篇是讲前端项目的,所以需要运行angular项目了,由于前端项 ...
- Angular(三)
Angular开发者指南(三)数据绑定 数据绑定AngularJS应用程序中的数据绑定是模型和视图组件之间的数据的自动同步. AngularJS实现数据绑定的方式可以将模型视为应用程序中的单一来源 ...
- Angular基础(三) TypeScript
一.模仿Reddit a) 运行ng new –ng4angular-reddit创建应用,从随书代码中复制样式文件,新建组件app-root,代码为: 界面可以看到了: b) 对于界面输入的数据,获 ...
- 从flask视角理解angular(三)ORM VS Service
把获取模型数据的任务重构为一个单独的服务,它将提供英雄数据,并把服务在所有需要英雄数据的组件间共享. @Injectable() export class HeroService { getHeroe ...
- [AIR] NativeExtension在IOS下的开发实例 --- ANE文件的打包(三)
来源:http://bbs.9ria.com/thread-102041-1-1.html 好了,前面的准备工作做的差不多了.此时我们应用有下面几个文件:extension.xml CoolEx ...
- angular打包(二):nw.js
1 npm build 把ng编译出dist 2 单独写一个package.json 放在dist文件夹里. { "name": "app", "ma ...
随机推荐
- uname、hostname命令
一.uname:显示系统信息. 语法: uname [OPTION] ... 描述 打印某些系统信息. 没有选项,与-s相同. -a,--all ...
- X86逆向6:易语言程序的DIY
易语言程序在中国的用户量还是很大的,广泛用于外挂的开发,和一些小工具的编写,今天我们就来看下如何给易语言程序DIY,这里是用的易语言演示,当然这门技术也是可以应用到任何一门编译型语言中的,只要掌握合适 ...
- hashMap,hashTable,TreeMap,concurrentHashMap区别
hashMap: 基于哈希表实现 treeMap: 基于二叉树实现,适用于排序 hashTable: 底层还是HashMap,在方法上加了同步 concurrentHashMap: java7底层通过 ...
- Maven maven-compiler-plugin 编译问题
问题:每次右键项目名-maven->update project 时候,项目jdk版本变了,变回1.5版本或者其他版本 解决方案一:修改maven的配置(解压目录的conf\setting.xm ...
- Leaflet个人封装笔记
<!DOCTYPE html> <html> <head> <link href="style/leaflet.css" type=&qu ...
- 向PHP发送HTTP-Post请求
欢迎访问我的个人博客,获取更多有用的东西 链接一 链接二 也可以关注我的微信订阅号:CN丶Moti 1.post.html <!DOCTYPE html> <html lang=&q ...
- nginx php-fpm环境搭建权限问题
如果nginx的work process和php-fpm的运行权限相同,在logrotate的影响下,会导致被上传webshell后 被修改accesslog 故安全配置: nginx.conf: u ...
- JVM类加载机制和内存模型
一.JVM类加载机制 首先需要了解一下类加载器(ClassLoader): ClassLoader是Java的一个核心组件,它主要作用是从系统外部获得Class二进制数据流,然后将数据流装载到系统,交 ...
- C#中UDP(Socket)
1 使用无连接的套接字,我们能够在自我包含的数据包里发送消息,采用独立的读函数读取消息,读取的消息是使用独立的发送函数发送的.但是UDP数据包不能保证可靠传输,存在许多的因素,比如网络繁忙等等,都有可 ...
- another-redis-desktop-manager
brew cask install another-redis-desktop-manager