vue首屏加载优化

2022-06-15  本文已影响0人  北暖37

业务需要,从A网站跳转到B网站,网站加载慢,白屏时间有十几秒,影响用户体验,对项目进行了优化

技术栈:vue2+webpack
1、vue-router路由懒加载
// 1、Vue异步组件技术:
{
  path: '/home',
  name: 'Home',
  component: resolve => require(['../views/home.vue'], resolve)
}

// 2、es6提案的import()
{
  path: '/',
  name: 'home',
  component: () => import('../views/home.vue')
}

// 3、webpack提供的require.ensure()
{
  path: '/home',
  name: 'Home',
  component: r => require.ensure([],() =>  r(require('../views/home.vue')), 'home')
}
2、cdn资源优化,

可以将vue,vue-router, vuex, axios等这些全家桶,改成cdn引入,同时vue.config.js引入进行修改

// index.html
<body>
  <div id="app"></div>
    <script src="https://cdn.bootcss.com/vue/2.6.10/vue.min.js"></script>
    <script src="https://cdn.bootcss.com/axios/0.19.0-beta.1/axios.min.js"></script>
    <script src="https://cdn.bootcss.com/vuex/3.1.0/vuex.min.js"></script>
    <script src="https://cdn.bootcss.com/vue-router/3.0.2/vue-router.min.js"></script>
    <script src="https://cdn.bootcss.com/element-ui/2.6.1/index.js"></script>
</body>


// vue.concong.js 配置externals属性
module.exports = {
 ···
    externals: {
      'vue': 'Vue',
      'vuex': 'Vuex',
      'vue-router': 'VueRouter',
      'axios':'axios'
    }
 }
3、通过webpack gzip压缩文件,同时ngixn配置gzip压缩

gzip 对基于文本格式文件的压缩效果最好(如:CSS、JavaScript 和 HTML),在压缩较大文件时往往可实现高达 70-90% 的压缩率

// 先安装   npm install compression-webpack-plugin --D
// vue.config.js
const CompressionPlugin = require('compression-webpack-plugin')
configureWebpack: (config) => {
  if (process.env.NODE_ENV === 'production') {
    config.plugins.push(
      new CompressionPlugin({
        // gzip压缩配置
        test: /\.js$|\.html$|\.css/, // 匹配文件名
        threshold: 10240, // 对超过10kb的数据进行压缩
        deleteOriginalAssets: false, // 是否删除原文件
      })
    )
  }
}
4、webpack-bundle-analyzer

利用webpack-bundle-analyzer分析大文件,找出内鬼,逐个优化

// 先安装  npm install webpack-bundle-analyzer -D
// vue.config.js
const BundleAnalyzerPlugin = require('webpack-bundle-analyzer').BundleAnalyzerPlugin  
module.exports = {     
   ...其它     
   configureWebpack: [         
   plugins: [             
      new BundleAnalyzerPlugin() // 分析打包大小使用默认配置         
   ]    
  },  
}

执行npm run build会自动打开服务,可以看到js大小


1.jpg

1.文件可以通过cdn引入,版本要对应
2.ant-design 按需引入
3.代码压缩,需要服务端配合

5、splitChunks 代码分割
config.optimization.splitChunks({ // 代码分割
      cacheGroups: {
        common: {
          name: 'chunk-common', // 打包后的文件名
          chunks: 'all', // 共有3个值"initial","async"和"all"。配置后,代码分割优化仅选择初始块,按需块或所有块
          minChunks: 2, // (默认值:1)在拆分之前共享模块的最小块数
          maxInitialRequests: 5, //(默认值为3)入口点的最大并行请求数
          minSize: 0, // (默认值:30000)块的最小大小
          priority: 1, // 数字越大优先级越高 (-10大于-20)
          reuseExistingChunk: true // 允许在模块完全匹配时重用现有的块,而不是创建新的块。
        },
        vendors: {
          name: 'chunk-vendors',
          test: /[\\/]node_modules[\\/]/,
          chunks: 'initial',
          priority: 2,
          reuseExistingChunk: true,
          enforce: true
        },
        antDesignVue: {
          name: 'chunk-ant-design-vue',
          test: /[\\/]node_modules[\\/]ant-design-vue[\\/]/,
          chunks: 'all',
          priority: 3,
          reuseExistingChunk: true,
          enforce: true
        }
      }
    })
2.png
6、移除preload&prefetch
// vue.config.js
chainWebpack: config => {
    // 移除 prefetch预取 插件
    config.plugins.delete('prefetch')
    // 移除 preload 预加载 插件 避免加载多余的资源
    config.plugins.delete('preload')
}
上一篇 下一篇

猜你喜欢

热点阅读