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