当前位置:首页 > 技术分析 > 正文内容

记一次Vite打包优化(vite 打包报错)

ruisui883个月前 (02-03)技术分析13

前言

近期为了上线 Module Federation ,发现项目 Vue-cli 版本太低用不了,就顺便把应用用 Vite 重新配置了下,发现打包后页面加载速度不理想,故开启一段优化之旅

目标和指标

既然要优化,那就必须有目标,能量化

目标

本次优化目标

  • 正常网速下,2s内加载完成

指标

关于指标,这里简单介绍下常见的优化指标

  • FCP(First Contentful Paint):白屏时间(第一个文本绘制时间)
  • Speed Index:首屏时间
  • TTI(Time To Interactive): 第一次可交互的时
  • lighthouse score:Chrome浏览器审查工具性能评分

开始性能分析

我们大部分的性能分析都可以借助 Chrome 完成,大致可以分为

Network 分析

Lighthouse 分析

Bundle 分析

Network 分析

从网络加载状态看可以发祥有一个 1.9MB 的 index.js 文件占用了比较大的加载时间,阻塞了其它资源的加载,是一个优化点

Lighthouse 分析

使用

结果

前面我们罗列的一些指标都可以在这里直观的看到数值,记录下来为我们调优后进行参考指标对比

Bundle 分析

因为使用的是 vite,借助插件 rollup-plugin-visualizer,来进行 bundle 分析

安装

pnpm i rollup-plugin-visualizer -D

引入

import { visualizer } from 'rollup-plugin-visualizer'

const plugins = [vue(), visualizer()]

打包之后会在项目根目录生成 stats.html 文件,打开

分析可以看出之前 index.js 加载慢很大一部分原因是因为加载了 echarts 包,这就给我门优化提供了方向

开始优化

通过之前的分析,主要的加载优化方向还是大体积文件瘦身(之前已经做过 gzip 的优化,如果没做过的同学强烈推荐,可以极大提升加载速度)

GZIP 配置

这里顺便介绍下 vite 的 GZIP 配置

安装 vite-plugin-compression

npm i vite-plugin-compression -D

修改 vite.config.js 配置

 import viteCompression from 'vite-plugin-compression'
 
 plugins: [vue(), viteCompression()]

打包后就会生成 gzip 文件了,但是服务端 nginx 还需要配置一下才能生效

http {
    gzip_static on;
    gzip_proxied any;
}

具体也可以看看我的这篇文章,有详细介绍

系统介绍浏览器缓存机制及前端优化方案

echarts 单独拆分

修改 vite.config.js 配置

build: {
    rollupOptions: {
        output: {
            manualChunks: {
                echarts: ['echarts']
            }
        }
    }
}

打包后 Index.js 体积变化(未压缩前)

Before: 4.49MB

After: 1.34MB

图片压缩

安装 vite-plugin-imagemin

npm i vite-plugin-imagemin -D

修改 vite.config.js 配置

import viteImagemin from "vite-plugin-imagemin"

plugins: [vue(), viteImagemin()]

打包后会生成压缩的图片,但是每次打包都会重新压缩一遍,比较浪费时间,如果不介意的话采用此方案也很简单,网上查了一下有使用本地压缩的方案,不过配置比较繁琐,就自己写了个插件,后续会有文章单独介绍,敬请关注

结果分析

Network 分析

加载时间 平均节省 1

Lighthouse 分析

分数由 46 提升到 52

Bundle 分析

主包体积缩小 1 M 左右

总结

到此本次优化告一段路,基本达到预期效果,不过遗留了一些问题,像引用 video 插件相关的一些页面想用开头提到的组件联邦 Module Federation来做,但是加载时部分手机浏览器出现兼容问题未能完成,后续等解决了兼容问题在单独写一篇总结 ^-^

扫描二维码推送至手机访问。

版权声明:本文由ruisui88发布,如需转载请注明出处。

本文链接:http://www.ruisui88.com/post/854.html

标签: vite.js
分享给朋友:

“记一次Vite打包优化(vite 打包报错)” 的相关文章

“韩版谷歌”Naver进军操作系统,发布自研免费Linux发行版

IT之家 12 月 11 日消息,有“韩版 Google”之称的 Naver 公司正式进军操作系统领域,发布了自主研发的 Linux 发行版 Navix,为企业提供了一个稳定、可靠且免费的 Linux 发行版选择。IT之家援引科技媒体 theregister 观点,此举效仿了谷歌的多元化发展战略,也...

Gitlab 的使用和代码审查流程介绍

1、先简洁介绍下项目常用的信息-面板统计页面2、用户信息面板3、服务器信息4、项目信息5、重点介绍代码提交审核机制和授权合并机制开发人员推送代码的时候不能直接推送到master,否则就会报错。此时开发人员要本地新建分支然后在提交上来列出修改了哪些细节管理员可以管理这些分支合并到master6、指派合...

gitlab简单搭建与应用

一、gitlab1、简介GitLab是利用Ruby on Rails一个开源的版本管理系统,实现一个自托管的Git项目仓库,可通过Web界面进行访问公开的或者私人项目。与Github类似,GitLab能够浏览源代码,管理缺陷和注释。可以管理团队对仓库的访问,它非常易于浏览提交过的版本并提供一个文件历...

Vue真是太好了 壹万多字的Vue知识点 超详细!

1??、Vue和其他两大框架的区别Angular 学习成本太高React 代码可读性差Vue 学习成本较低 很容易上手VUE官方: https://cn.vuejs.org/v2/guide/comparison.html?2??、Vue是什么Vue是一套用于构建用户界面的渐进式框架 "前端...

Vue中的路由配置常用属性

router:路由页面跳转的核心库;引入路由:import VueRouter from 'vue-router'; 注册路由:const router = new VueRouter({ })mode:模式路由有hash history两种模式:hash模式URL中包含#,#后边是...

微信小程序发展越来越快,Flutter应用开发越来越低效?

目前的疑惑微信小程序发展的越来越快,目前小程序甚至取代了大部分 App 的生态位,公司的坑位不增反降,只能让原生应用开发兼顾或换岗进行小程序的开发。以我的实际情况来讲,公司应用采用的 Flutter 框架,同样的功能不可避免的就会存在 Flutter 应用开发和微信小程序开发兼顾的情况,这种重复造轮...