Rumah hujung hadapan web View.js vue加载优化策略有哪些

vue加载优化策略有哪些

Nov 18, 2020 am 11:53 AM
Pengoptimuman memuatkan

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

vue加载优化策略有哪些

【相关文章推荐: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
Salin selepas log masuk

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

{
  "plugins": [["import", {
    "libraryName": "iview",
    "libraryDirectory": "src/components"
  }]]
}
Salin selepas log masuk

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

  下面是iview的一个例子

7ca5fcedfa855a3da58d04e86731c57.png

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

Vue.prototype.$Notice = Notice;
Salin selepas log masuk

  这样我们就可以正常的使用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
Salin selepas log masuk

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(视频)

Atas ialah kandungan terperinci vue加载优化策略有哪些. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Kenyataan Laman Web ini
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn

Tag artikel panas

Notepad++7.3.1

Notepad++7.3.1

Editor kod yang mudah digunakan dan percuma

SublimeText3 versi Cina

SublimeText3 versi Cina

Versi Cina, sangat mudah digunakan

Hantar Studio 13.0.1

Hantar Studio 13.0.1

Persekitaran pembangunan bersepadu PHP yang berkuasa

Dreamweaver CS6

Dreamweaver CS6

Alat pembangunan web visual

SublimeText3 versi Mac

SublimeText3 versi Mac

Perisian penyuntingan kod peringkat Tuhan (SublimeText3)

Bagaimana saya membuat dan menggunakan plugin tersuai dalam vue.js? Bagaimana saya membuat dan menggunakan plugin tersuai dalam vue.js? Mar 14, 2025 pm 07:07 PM

Bagaimana saya membuat dan menggunakan plugin tersuai dalam vue.js?

Cara mengkonfigurasi jam tangan komponen dalam lalai eksport vue Cara mengkonfigurasi jam tangan komponen dalam lalai eksport vue Mar 04, 2025 pm 03:30 PM

Cara mengkonfigurasi jam tangan komponen dalam lalai eksport vue

Cara mengkonfigurasi cangkuk kitaran hayat komponen di Vue Cara mengkonfigurasi cangkuk kitaran hayat komponen di Vue Mar 04, 2025 pm 03:29 PM

Cara mengkonfigurasi cangkuk kitaran hayat komponen di Vue

Apa itu Vuex dan bagaimana saya menggunakannya untuk pengurusan negeri dalam aplikasi Vue? Apa itu Vuex dan bagaimana saya menggunakannya untuk pengurusan negeri dalam aplikasi Vue? Mar 11, 2025 pm 07:23 PM

Apa itu Vuex dan bagaimana saya menggunakannya untuk pengurusan negeri dalam aplikasi Vue?

Apakah ciri-ciri utama Vue.js (seni bina berasaskan komponen, DOM maya, pengikatan data reaktif)? Apakah ciri-ciri utama Vue.js (seni bina berasaskan komponen, DOM maya, pengikatan data reaktif)? Mar 14, 2025 pm 07:05 PM

Apakah ciri-ciri utama Vue.js (seni bina berasaskan komponen, DOM maya, pengikatan data reaktif)?

Bagaimanakah saya mengkonfigurasi Vue CLI untuk menggunakan sasaran binaan yang berbeza (pembangunan, pengeluaran)? Bagaimanakah saya mengkonfigurasi Vue CLI untuk menggunakan sasaran binaan yang berbeza (pembangunan, pengeluaran)? Mar 18, 2025 pm 12:34 PM

Bagaimanakah saya mengkonfigurasi Vue CLI untuk menggunakan sasaran binaan yang berbeza (pembangunan, pengeluaran)?

Bagaimanakah saya melaksanakan teknik penghalaan lanjutan dengan Vue Router (laluan dinamik, laluan bersarang, pengawal laluan)? Bagaimanakah saya melaksanakan teknik penghalaan lanjutan dengan Vue Router (laluan dinamik, laluan bersarang, pengawal laluan)? Mar 11, 2025 pm 07:22 PM

Bagaimanakah saya melaksanakan teknik penghalaan lanjutan dengan Vue Router (laluan dinamik, laluan bersarang, pengawal laluan)?

Bagaimanakah saya menggunakan Vue dengan Docker untuk penggunaan kontena? Bagaimanakah saya menggunakan Vue dengan Docker untuk penggunaan kontena? Mar 14, 2025 pm 07:00 PM

Bagaimanakah saya menggunakan Vue dengan Docker untuk penggunaan kontena?

See all articles