• 技术文章 >web前端 >Vue.js

    vue加载优化策略有哪些

    coldplay.xixicoldplay.xixi2020-11-18 11:53:56原创585

    vue加载优化策略:1、路由懒加载;2、组件按需加载;3、使用CDN加速策略;4、使用【compression-webpack-plugin】将文件打包成gzip格式。

    【相关文章推荐:vue.js

    vue加载优化策略:

    方法一、路由懒加载

      首屏加载慢的原因无非就是单页面应用需要加载完整个路由表上的页面,而路由懒加载就是来解决这个问题的。如果我们能把不同路由对应的组件分割成不同的代码块,然后当路由被访问的时候才加载对应组件,这样就更加高效了。下面这个就是vue路由懒加载的一个具体例子。方法很简单,如果您不想深入了解,只需按照这个格式引入路由就可以了。如果您对路由懒加载感兴趣,请移步vue-router路由懒加载

    b92caf1a972a690823a6df3407ed93b.png

    方法二、组件按需加载

      为什么要按需加载组件呢?原因也很简单,一些组件库包含丰富的组件,如果我们直接将其引入,不免会引入一些我们压根用不到的组件。这样打包起来体积会比较大,同样显得我们很不专业。因此按需引入就显得很必要了。我们现在就拿iview组件库为例,了解一下按需引入的流程。

    1.首先引入按需加载工具 babel-plugin-import

      babel-plugin-import是babel它会在编译过程中将 import 的写法自动转换为按需引入的方式。

    npm install babel-plugin-import --save-dev

    2.在项目根目录创建.babelrc文件并配置按需加载内容

    {
      "plugins": [["import", {
        "libraryName": "iview",
        "libraryDirectory": "src/components"
      }]]
    }

    3.在main.js配置项目需要加载的组件

      下面是iview的一个例子

    7ca5fcedfa855a3da58d04e86731c57.png

      这里需要注意全局注册的组件需要挂在到vue原型上,例如我们需要使用Notice组件,那我就需要

    Vue.prototype.$Notice = Notice;

      这样我们就可以正常的使用iview的组件了。

    方法三、使用CDN加速策略

      在Vue项目中,引入到工程中的所有js、css文件,编译时都会被打包进vendor.js,那么vendor.js文件体积将会相当的大,影响首开的体验。解决方法是,将引用的外部js、css文件剥离开来,不编译到vendor.js中,而是用资源的形式引用,这样浏览器可以使用多个线程异步将vendor.js、外部的js等加载下来,达到加速首开的目的。外部的库文件,就可以使用CDN资源。vue cli3.x在配置cdn是和vue cli2.x有一些区别,vue cli在升级后,代码结构变化比较大,配置文件集成到了vue.config.js文件中。下面以amap、axios和qs为例讲述如何使用cdn加载资源。

    1.在index.html中引入相关cdn资源

    99ebd1b30263a9e9dbda3187e8c65e7.png

    2.配置externals

      vue cli3.x 配置webpack是在vue.config.js的configureWebpack中

    c51b8ed3a5fd5e19fa0681dfd8c572f.png

      配置完之后,我们就可以正常使用全局的Amap、axios和Qs了

    方法四、使用compression-webpack-plugin将文件打包成gzip格式

      compression-webpack-plugin这个依赖在npm run build是会生成.gz文件。之后项目访问的文件就是这个.gz文件,正常的项目打包体积会减少一半还要多,是不是很吊

    7abb187984f1e8f6623f8602157df8f.png

      下面我们来进一步讲述这个这个依赖的使用流程。

    1.npm 引入

    npm install compression-webpack-plugin  --save-dev

    2.vue cli3.x在 vue.config.js配置webpack

    fa8c4958eff8755d55cca10c6cbb93f.png

    3.nginx开启gzip模式

      在上一步前端就已经配置好了,之后就是nginx配合开启gzip模式,这个比较简单,只要你对nginx有一点了解,我们在nginx.conf中的http中配置一些代码

    171ebed87aecc07e708f5e13f5f3191.png

    4.验证是否配置成功

      这步就很简单了只需要查看chunk类文件的Response Headers的Content-Encoding是否是gzip即可

    8e3d98090745d4fec8b46a8751b8033.png

    相关免费学习推荐:JavaScript(视频)

    以上就是vue加载优化策略有哪些的详细内容,更多请关注php中文网其它相关文章!

    声明:本文原创发布php中文网,转载请注明出处,感谢您的尊重!如有疑问,请联系admin@php.cn处理
    专题推荐:加载优化
    上一篇:怎么检查vue.js是否安装成功了 下一篇:怎么关闭vue.js中的空格报错?
    线上培训班

    相关文章推荐

    • 如何进行脚本加载优化• vuejs项目打包与首屏加载优化• vue-router懒加载优化加载速度• 关于vue首屏加载优化的介绍

    全部评论我要评论

  • 取消发布评论发送
  • 1/1

    PHP中文网