vue-cli4首次加载速度优化代码

目录
文章目录隐藏
  1. GZIP 压缩
  2. CDN
  3. 路由懒加载

GZIP 压缩

GZIP 压缩有动态跟静态两种
可以将由前端打包GZIP,通过 gzip_static:on会寻找以.gz结尾的文件,直接返回,不会占用 cpu 进行压缩,如果找不到则不进行压缩

nginx

#开启和关闭 gzip 模式
gzip on|off;
    
#gizp 压缩起点,文件大于 1k 才进行压缩
gzip_min_length 1k;
    
# gzip 压缩级别,1-9,数字越大压缩的越好,也越占用 CPU 时间
gzip_comp_level 5;
    
# 进行压缩的文件类型。
gzip_types text/plain application/javascript application/x-javascript text/css application/xml text/javascript ;
    
#nginx 对于静态文件的处理模块,开启后会寻找以.gz 结尾的文件,直接返回,不会占用 cpu 进行压缩,如果找不到则不进行压缩
gzip_static on|off
    
# 是否在 http header 中添加 Vary: Accept-Encoding,建议开启
gzip_vary on;

# 设置压缩所需要的缓冲区大小,以 4k 为单位,如果文件为 7k 则申请 2*4k 的缓冲区 
gzip_buffers 2 4k;

# 设置 gzip 压缩针对的 HTTP 协议版本
gzip_http_version 1.1;

vue.config.js

// npm i -D compression-webpack-plugin
const CompressionPlugin = require('compression-webpack-plugin')

configureWebpack: {
/* 打包时开启 GZIP 压缩 */
  plugins: [
    new CompressionPlugin({
          algorithm: 'gzip', // 使用 gzip 压缩
          test: /\.js$|\.html$|\.css$/, // 匹配文件名
          filename: '[path].gz[query]', // 压缩后的文件名(保持原文件名,后缀加.gz)
          minRatio: 1, // 压缩率小于 1 才会压缩
          threshold: 10240, // 对超过 10k 的数据压缩
          deleteOriginalAssets: false, // 是否删除未压缩的源文件,谨慎设置,如果希望提供非 gzip 的资源,可不设置或者设置为 false(比如删除打包后的 gz 后还可以加载到原始资源文件)
    }),
  ]
}

CDN

const isProd = process.env.NODE_ENV === 'production'
const cdn = {
  externals: {
    // 业务使用示例 => key:包名  value:库文件对应的全局对象字符串=>可以冲源码最后获取
    vue: 'Vue',
    'vue-router': 'VueRouter',
    vuex: 'Vuex',
    axios: 'axios',
    'ant-design-vue': 'antd',
    'vue-ls': 'VueStorage',
  },
  // import 的 css 不要放进来,externals 无法过滤掉
  css: [],
  js: [
    '//unpkg.com/vue@2.6.12/dist/vue.min.js',
    '//unpkg.com/vue-router@3.4.9/dist/vue-router.min.js',
    '//unpkg.com/vuex@3.5.1/dist/vuex.min.js',
    '//unpkg.com/axios@0.21.0/dist/axios.min.js',
    '//unpkg.com/ant-design-vue@1.7.2/dist/antd.min.js',
    '//unpkg.com/vue-ls@3.2.1/dist/vue-ls.min.js',
  ]
};

configureWebpack: config => {
  config.externals = isProd ? cdn.externals : {}
},
chainWebpack: config => {
    config.plugin('html').tap(args => {
            // html 中添加 cdn
            args[0].cdn = cdn
            return args
          })
}

index.html

<!DOCTYPE html>
<html lang="en">
<head>
  <meta charset="utf-8">
  <meta http-equiv="X-UA-Compatible" content="IE=edge">
  <meta name="viewport" content="width=device-width,initial-scale=1.0">
  <link rel="icon" href="<%= BASE_URL %>favicon.ico">
  <title><%= htmlWebpackPlugin.options.title %></title>
  <link rel="stylesheet" href="//at.alicdn.com/t/font_1825329_krt0759dhsh.css" />
  <!-- htmlWebpackPlugin.options.cdn 在 vue.config.js 内配置 -->
  <!-- 使用 CDN 的 CSS 文件 -->
  <% for (var i in htmlWebpackPlugin.options.cdn && htmlWebpackPlugin.options.cdn.css) { %>
  <link rel="stylesheet" href="<%= htmlWebpackPlugin.options.cdn.css[i] %>" />
  <% } %>
</head>
<body>
  <noscript>
    <strong>We're sorry but <%= htmlWebpackPlugin.options.title %> doesn't work properly without JavaScript enabled.
      Please enable it to continue.</strong>
  </noscript>
  <div id="app"></div>
  <!-- 使用 CDN 的 JS 文件 -->
  <% for (var i in htmlWebpackPlugin.options.cdn && htmlWebpackPlugin.options.cdn.js) { %>
  <script type="text/javascript" src="<%= htmlWebpackPlugin.options.cdn.js[i] %>"></script>
  <% } %>
</body>
</html>

路由懒加载

使用 ()=>import('xxx')懒加载路由组件,可以添加magic comments,打包后会单独生成chunk.[hash].js文件,进一步减小主包大小

// Magic Comments 详情查看下方链接
// https://webpack.docschina.org/api/module-methods/#magic-comments
{
    path: '/login',
    name: 'login',
    component: () => import(/* webpackChunkName: "my-chunk-name" */'@/views/login/Login'),
    hidden: true,
  },

「点点赞赏,手留余香」

0

给作者打赏,鼓励TA抓紧创作!

微信微信 支付宝支付宝

还没有人赞赏,快来当第一个赞赏的人吧!

声明:本站所有文章,如无特殊说明或标注,均为本站原创发布。任何个人或组织,在未征得本站同意时,禁止复制、盗用、采集、发布本站内容到任何网站、书籍等各类媒体平台。如若本站内容侵犯了原著者的合法权益,可联系我们进行处理。
码云笔记 » vue-cli4首次加载速度优化代码

发表回复