angular:trunk包探究

问题:

如题

解决方案:

(一)service

1.providein为root的service,抽离只需要的部分单独注入。

如果有很多不需要被主界面及主界面模块调用的方法和属性,应该将只需要的内容抽离出来,单独注入到使用的地方。试验过,rootin导致service下所有代码都会被注入,没有进行代码剪枝。

2.providein为非root也一样,因为如果在main.js,和root一样的效果,其他地方不会有备份。所以也应该精简

3.直接注入组件,代码会在common.js;组件providedin注入,会在组件所在的模块(如果每个组件单独注入,则会存在多个组件中?暂时未验证?模块级别则每个模块单独一份?猜测是的,因为这样符合service实际内存占用结果)

4.service继承可以减少重复代码

(二)lazy load

通配路由**也可以lazy load,需要注意的是不能有children路由,否则会报错。因为通配已经匹配了所有,故无法再有子路由

(三)route.module

如果子路由非常多,那么这个路由的配置也将非常大,有优化思路但是没有找到现成框架。另外这部分大小貌似在webpack-bundle-analyzer中无法体现,我通过注释前后打包看到main.js文件大小变化得到的结论

(webpack-bundle-analyzer使用参考:

Angular部署优化工具:webpack-bundle-analyzer | TonyStudio

(四)静态module

即使module类里的代码没有用到,如果是被appmodule直接用到(非懒加载使用),其代码不会剪枝,所有内容都会进入main.js中,因此需要注意相关代码膨胀问题

相关推荐
有事没事实验室4 分钟前
node.js中的path模块
前端·css·node.js·html·html5
十盒半价14 分钟前
TypeScript + React:大型项目开发的黄金搭档
前端·typescript·trae
楚轩努力变强1 小时前
前端工程化常见问题总结
开发语言·前端·javascript·vue.js·visual studio code
鱼樱前端1 小时前
rust基础二(闭包)
前端·rust
菜鸟学Python1 小时前
Python web框架王者 Django 5.0发布:20周年了!
前端·数据库·python·django·sqlite
前端开发爱好者2 小时前
只有 7 KB!前端圈疯传的 Vue3 转场动效神库!效果炸裂!
前端·javascript·vue.js
pe7er2 小时前
RESTful API 的规范性和接口安全性如何取舍
前端·后端
Fly-ping2 小时前
【前端】JavaScript文件压缩指南
开发语言·前端·javascript
接口写好了吗2 小时前
【el-table滚动事件】el-table表格滚动时,获取可视窗口内的行数据
javascript·vue.js·elementui·可视窗口滚动
未来之窗软件服务3 小时前
免费版酒店押金原路退回系统之【房费押金计算器】实践——仙盟创梦IDE
前端·javascript·css·仙盟创梦ide·东方仙盟·酒店押金系统