vue 路由懶加載詳情
1、什么是路由懶加載
官方的解釋:
- 當(dāng)打包構(gòu)建應(yīng)用時,
JavaScript
包會變得非常大,影響頁面加載。 - 如果我們能把不同路由對應(yīng)的組件分割成不同的代碼塊,然后當(dāng)路由被訪問的時候才加載對應(yīng)組件,這樣就更加高效了。
官方想表達(dá)的意思
- 首先,我們知道路由中通常會定義很多不同的頁面
- 這個頁面最后會被打包到哪里呢?一般情況下是會放在一個js文件中
- 但是頁面這么多,所有文件都放到一個js文件中,必然會造成這個頁面會非常的大
- 如果我們一次性從服務(wù)器中請求下來這個頁面,可能需要花費(fèi)一定的時間,甚至用戶的電腦上會出現(xiàn)短暫空白的情況
- 如何避免這種情況?使用路由懶加載即可
路由懶加載做了什么
路由懶加載的主要作用是將路由對應(yīng)的組件打包成一個個js代碼塊
只要在這個路由被訪問到的時候,才加載對應(yīng)的組件
2、路由懶加載的使用
在使用之前,我們先來看看原先代碼是如何加載路由的
import Vue from "vue"; import VueRouter from "vue-router"; import Home from "@/views/Home"; import About from "@/views/About"; import User from "@/views/User"; Vue.use(VueRouter); const routes = [ { path: "/", name: "Home", component: Home, }, { path: "/about", name: "About", component: About }, { path: "/user/:userId", name: "User", component: User } ];
我們看到從一開始我們就導(dǎo)入了路由對應(yīng)的組件,如果需要的導(dǎo)入的組件非常多,那么加載頁面就會相對較慢,我們來看下這種方式打包出來的文件
我們看到這種方式打包出來的文件只有2個js文件,之后我們加載頁面的時候,需要把這2個文件全部加載完,頁面才會展示,如果代碼量過多,那么頁面響應(yīng)就比較慢,給用戶體驗(yàn)非常不好
接下來我們使用路由懶加載
import Vue from "vue"; import VueRouter from "vue-router"; Vue.use(VueRouter); // 新增路由懶加載代碼 const Home = () => import('../views/Home') const About = () => import('../views/About') const User = () => import('../views/User') const routes = [ { path: "/", name: "Home", component: Home, }, { path: "/about", name: "About", component: About }, { path: "/user/:userId", name: "User", component: User } ];
我們看到,在路由配置中什么都不需要改變,只需要像往常一樣使即可,只是在這之前聲明了一個變量,變量中使用箭頭函數(shù)來導(dǎo)入對應(yīng)的組件,使用起來非常簡單。
使用路由懶加載的方式打包出來的文件結(jié)構(gòu)如下:
我們可以看到比原來的方式多出了3個js文件,這是因?yàn)槲覀兩厦娲a3個組件使用了路由懶加載,這3個js文件只有路由被訪問到了才會去加載,能省下不少的加載時間
所以我們更推薦使用路由懶加載的方式去加載路由
到此這篇關(guān)于vue 路由懶加載詳情的文章就介紹到這了,更多相關(guān)vue 路由懶加載 內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
詳細(xì)聊聊前端如何實(shí)現(xiàn)token無感刷新(refresh_token)
實(shí)現(xiàn)token無感刷新對于前端來說是一項(xiàng)非常常用的技術(shù),其本質(zhì)是為了優(yōu)化用戶體驗(yàn),下面這篇文章主要給大家介紹了關(guān)于前端如何實(shí)現(xiàn)token無感刷新(refresh_token)的相關(guān)資料,需要的朋友可以參考下2022-11-11vue實(shí)現(xiàn)移動端輕量日期組件不依賴第三方庫的方法
這篇文章主要介紹了vue 移動端輕量日期組件不依賴第三方庫,需要的朋友可以參考下2019-04-04Vue.js 單頁面多路由區(qū)域操作的實(shí)例詳解
這篇文章主要介紹了 Vue.js 單頁面多路由區(qū)域操作的實(shí)例詳解的相關(guān)資料,需要的朋友可以參考下2017-07-07vue組件中iview的modal組件爬坑問題之modal的顯示與否應(yīng)該是使用v-show
這篇文章主要介紹了vue組件中iview的modal組件爬坑問題之modal的顯示與否應(yīng)該是使用v-show,本文通過實(shí)例圖文相結(jié)合的形式給大家介紹的非常詳細(xì),具有一定的參考借鑒價值,需要的朋友可以參考下2019-04-04defineProperty和Proxy基礎(chǔ)功能及性能對比
這篇文章主要為大家介紹了defineProperty和Proxy基礎(chǔ)功能及性能對比,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2022-08-08