关于优化H5项目-按需加载

现状:

当把所有的代码打包到一个JS bundle文件里,就是个问题,产品功能业务的逐步增加,导致的最直观的后果就是bundle文件越来越大。随之而来的,用户打开网页的时间就会逐步增加,因为用户能看到网页的前提是要等把整个bundle给下载下来,如果这bundle比较大,用户网络不是那么好、这体验就槽糕了。

 

解决说明:

我们可以根据实际业务需求将代码进行分割(根据访问的路由),然后在合适的时候在将其加载进入文档中,利用webpack打包,生成不同的bundle文件,来实现代码的分离

好处在于:

1.只加载需要或是加载想要的模块,更合理:

比如app的评价界面,是h5的业务,我只用加载H5的评价模块以及登录判定模块就好,别的一些app自身就有,不用再加载了(比如商品详情、添加地址等模块跟当前业务没关联的)

 

2.适应性好

APP预存公共lib.js 要依赖客户端, 要注意更新时机,对于通过浏览器或是微信端访问的基本不适应了诶,并非通解,而按需加载 无论是app还是web网页都正常。

 

3.改动少、效果明显

从目前的改造的结果看来,不需要调整特别多,理解dva的设计,改动起来就2小时。对比之前的网页、首次加载JS大小只有之前一半,提升了50%,还有优化空间。(打开chrom浏览器,右键检查 赛选JS 可以看到)

 

数据结果对比:

未分离(assets.js是用来加载最新js,jweixin是微信相关,app*js是h5的bundle包)

5dd619d88457ae37b473b5593349d18c5cc.jpg

 

分离后(app*js是app bundle包、Market*js是首页)

0b584fdfd5b6b47e3e60e2ad4a07851c61e.jpg

 

分离后的203kb+25.4kb 是经过gzip压缩后的大小、也就是在客户端是要进行解压的、

未分离: 1.7MB ---经过gzip--->413kb 客户端解压也基本要花近2秒左右、

 

(而唯一的大头就是app*.js,这文件目前是h5的整个/下的根路由,加载模块较多、可以再优化。)

 

总结:

通过按需加载可以极大减少加载网页时间,代码越多,优势越明显。目前主流是通过 路由拆分,通过webpack生成不同的chunk包、加载过程中通过dva提供的dva-loading 过渡加载过程 来做。或是通过提取公共库,而不跟业务模块关联,保证hash值 ,再利用浏览器缓存也能提升效率。

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

转载于:https://my.oschina.net/u/3982963/blog/3020465

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Vue H5 性能优化的方法有很多,以下是一些常见的优化技巧: 1. 减少 HTTP 请求:合并和压缩 JavaScript 和 CSS 文件,使用图标字体代替图像,使用雪碧图等技术来减少网络请求次数。 2. 懒加载:对于大型的页面或者图片资源,使用懒加载技术来延迟加载,只有在要的时候再加载,可以提升页面的初始加载速度。 3. 代码拆分:将代码拆分成多个小模块,按加载,减少首次加载的文件大小和时间。 4. 缓存优化:使用浏览器缓存策略来缓存静态资源,减少重复请求。可以通过设置 HTTP 缓存头信息、使用 Service Worker 等技术实现。 5. 优化图片:使用合适的图片格式和压缩技术,如使用 WebP 格式替代 JPEG、PNG 格式,使用图片压缩工具来减小图片文件大小。 6. 减少重绘和回流:避免频繁的 DOM 操作和样式改变,可以使用 CSS3 动画代替 JavaScript 动画,利用 CSS3 的 transform 和 opacity 等属性来进行动画效果。 7. 优化页面渲染:使用虚拟列表、无限滚动等技术来优化大量数据的渲染,减少 DOM 元素的数量。 8. 使用路由懒加载:将路由按加载,减少初始加载时的资源消耗。 9. 避免不必要的计算和渲染:在 Vue 组件中,尽量避免在模板中使用复杂的计算属性和方法,可以使用 v-if、v-show 等指令来控制组件的显示和隐藏。 10. 使用生产环境构建:在生产环境中使用 Vue CLI 或者其他打包工具进行构建时,可以开启代码压缩、混淆、去除注释等优化选项,减小文件大小。 这些是一些常见的 Vue H5 性能优化方法,根据具体的项目求和场景,可以选择合适的优化策略来提升页面性能。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值