当前位置: 首页 > news >正文

常规VUE项目优化实践,跟着做就对了!

总结:

主要优化方式:

  1. imagemin优化打包大小(96M->50M),但是以打包速度为代价,通过在构建过程中压缩图片来实现,可根据需求开启。
  2. 字体压缩:目前项目内引用为思源字体,打包为24M。实践通过压缩字体会导致丢失一些属性,而字蛛等插件压缩只支持静态资源,对服务端获取的数据无法完美匹配。
    目前解决方案,仅用SourceHanSansSC-Medium字体,舍弃Normal及Regular字体。
  3. Gzip前端(50M->46M)针对css,js等代码进行压缩。
  4. Gzip服务端(通过nginx.conf的镜像文件实现前端配置)
  5. 本地构建速度(134s->67s):通过引入CDN和Echarts按需加载方式提升本地构建速度,目前已接近优化的极限,因为目前项目基本框架为vben-admin(官网并不推荐,后期为更换为vben-admin-thin,官网纯净版代码打包速度为122s)

仍需优化:

  1. 服务端用pnpm(官网推荐,下载,打包速度更快)
  2. 删除框架内无用的组件(可更换为vben-admin-thin一劳永逸)

以下为详情过程~

dev环境现况:

在这里插入图片描述

● LCP (Largest Contentful Paint) 代表的是视窗最大可见图片或者文本块的渲染时间。一般是至少75%用户能够在2.5秒内。
在这里插入图片描述

● 项目打包为将近97M
在这里插入图片描述

● 本地构建速度约134s。

具体步骤:

1、安装 rollup-plugin-visualizer 插件,此插件可以展示构建时长、chunk 数量及大小,目前可以分析为项目内最大占比为静态资源。
在这里插入图片描述

2、通过imagemin插件压缩图片并删除无用图上,压缩后的体积减少到50M

在这里插入图片描述
在这里插入图片描述

3、gzip前端代码压缩
4、cdn引入的vue, vue-router ,ant-design-vue
5、按需加载echarts
在这里插入图片描述

现况:
● 打包后的体积为46M
● 可以看到目前最大的模块不再是静态资源 而是echarts等外部资源库
在这里插入图片描述

● 同样以我本地为测试环境,打包速度优化至65s
在这里插入图片描述

● 优化后的首屏加载速度为2s内

在这里插入图片描述

http://www.lryc.cn/news/113260.html

相关文章:

  • PLL 的 verilog 实现
  • 【Hystrix技术指南】(1)基本使用和配置说明
  • Oracle EBS OM客制化调用API创建销售订单非常慢(FND_FLEX_HASH死锁)
  • 【leetcode】394. 字符串解码
  • 系统架构设计高级技能 · 系统质量属性与架构评估(二)【系统架构设计师】
  • 魅族Pandaer手机壳
  • F5洞察2023年网络威胁,助力网络安全防护
  • 从零构建深度学习推理框架-4 框架中的算子注册机制
  • 使用vscode+ssh免密远程Linux
  • rust-异步学习
  • 【Azure】office365邮箱测试的邮箱账号因频繁连接邮箱服务器而被限制连接 引起邮箱显示异常
  • 重新登录成功和登录失败处理器
  • 【Spring】(三)Spring 使用注解存储和读取 Bean对象
  • ParallelCollectionRDD [0] isEmpty at KyuubiSparkUtil.scala:48问题解决
  • ---------------- 部署 Zookeeper 集群 ----------------
  • SpringBoot 依赖管理和自动配置---带你了解什么是版本仲裁
  • c语言每日一练(2)
  • 代码随想录第三十七天
  • Linux进程间通信--ftok
  • Spring Boot集成Mybatis-Plus
  • 梳理日常开发涉及的负载均衡
  • IEEE 754 浮点数运算
  • 阿里巴巴Java开发手册学习记录
  • 论文阅读---《Unsupervised T ransformer-Based Anomaly Detection in ECG Signals》
  • 收藏这8个好用的原型设计工具,轻松制作原型图
  • 王道计网 第四章笔记
  • C# Blazor 学习笔记(9):动态css/class绑定
  • vue3学习-Pinia状态管理
  • TextBrewer:融合并改进了NLP和CV中的多种知识蒸馏技术、提供便捷快速的知识蒸馏框架、提升模型的推理速度,减少内存占用
  • 乍得ECTN(BESC)申请流程