半秒开!还有谁!!!

这是我的网站登录页目前加载时间,毫秒级加载,嗖的一下就出来啦,现在总结一下怎么做到的

一,路由 懒加载,这是常规操作

二,UI组件库动态导入

一定不要在入口main.js里全部注册组件,使用插件动态自动导入

css 复制代码
import AutoImport from 'unplugin-auto-import/vite'
import Components from 'unplugin-vue-components/vite'
import { ElementPlusResolver } from 'unplugin-vue-components/resolvers'
...
...
plugins: [
  vue(),
  AutoImport({
    resolvers: [ElementPlusResolver()],
  }),
  Components({
    resolvers: [ElementPlusResolver()],
  }),
],

三,合适的分包策略

我的项目有一键打包部署的指令,有兴趣可以找找我之前的博客 # 一条命令实现打包并自动部署 有了这个工具,改了配置之后可以一键部署看效果,实践是检验真理的唯一标准

这里有个点要非常注意:已经使用里组件动态导入,就不要这一行。'ui-vendor': 'element-plus'

这是第一版,我感觉还有可优化空间,就换了个策略,果真,进步很大

arduino 复制代码
output: {
  manualChunks: {
    // 把 Vue 全家桶单独打包
    'vue-vendor': ['vue', 'vue-router', 'pinia'],
    // 把 UI 库单独打包
    // 'ui-vendor': ['element-plus'], 组件库动态导入,不能加这个
    // 把图表库单独打包
    'chart-vendor': ['echarts'],
    'three':['three']
  }
}

以下是目前的配置

css 复制代码
output: {
    manualChunks: { 
    // 只保留 Vue 核心,让 UI 库自动按需分包 
    'vue-core': ['vue', 'vue-router', 'pinia'],
    }, 
    // 让 Vite 自动优化 chunk 分割 
    chunkFileNames: 'assets/[name]-[hash].js',
 }

四,nginx开始Gzip压缩

bash 复制代码
gzip on;
gzip_min_length 1k;
gzip_comp_level 6;
gzip_types text/plain text/css text/xml text/javascript application/json application/javascript application/xml+rss application/rss+xml application/atom+xml application/ld+json application/manifest+json image/svg+xml;
gzip_http_version 1.1;
gzip_vary on;
gzip_disable "msie6";

五,还有其他零碎的方法,巴拉巴拉一大堆

  1. 开启 HTTP/2 需要https证书,我没有 2. CDN 加速 我没有弄 3. 图片懒加载 图片少,没有弄 4. 还有我没有想起来啦,朋友们补充下
相关推荐
代码搬运媛2 小时前
git 下中文文件名乱码问题解决
前端
CaffeinePro2 小时前
告别知识点零散!React零基础通关,从环境搭建到Ant Design页面实战
前端·react.js
cidy_982 小时前
水龙头领不到测试币?手把手用 Hardhat 本地环境零门槛学以太坊交易
前端
因_崔斯汀2 小时前
Three.js 3D 地图特效与材质实现指南
前端
angerdream2 小时前
手把手编写儿童手机远程监控App之vue3用 AI Agent生成菜单
前端
cidy_982 小时前
Git Pull 代码冲突后完整回退教程
前端
JING小白2 小时前
Day 1 重学Vue:响应式系统的“底层逻辑”变更,Vue2旧时代的终结与Vue3新时代的开启
前端·vue.js
这个DBA有点耶2 小时前
SQL改写进阶:标量子查询的“隐形代价”与消除实战
数据库·mysql·架构
张就是我1065922 小时前
一个 ZIP 文件,把 webshell 写到了不该在的地方
前端