vue 路由懶加載詳情
1、什么是路由懶加載
官方的解釋:
- 當(dāng)打包構(gòu)建應(yīng)用時(shí),
JavaScript包會變得非常大,影響頁面加載。 - 如果我們能把不同路由對應(yīng)的組件分割成不同的代碼塊,然后當(dāng)路由被訪問的時(shí)候才加載對應(yīng)組件,這樣就更加高效了。
官方想表達(dá)的意思
- 首先,我們知道路由中通常會定義很多不同的頁面
- 這個(gè)頁面最后會被打包到哪里呢?一般情況下是會放在一個(gè)js文件中
- 但是頁面這么多,所有文件都放到一個(gè)js文件中,必然會造成這個(gè)頁面會非常的大
- 如果我們一次性從服務(wù)器中請求下來這個(gè)頁面,可能需要花費(fèi)一定的時(shí)間,甚至用戶的電腦上會出現(xiàn)短暫空白的情況
- 如何避免這種情況?使用路由懶加載即可
路由懶加載做了什么
路由懶加載的主要作用是將路由對應(yīng)的組件打包成一個(gè)個(gè)js代碼塊
只要在這個(gè)路由被訪問到的時(shí)候,才加載對應(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個(gè)js文件,之后我們加載頁面的時(shí)候,需要把這2個(gè)文件全部加載完,頁面才會展示,如果代碼量過多,那么頁面響應(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
}
];
我們看到,在路由配置中什么都不需要改變,只需要像往常一樣使即可,只是在這之前聲明了一個(gè)變量,變量中使用箭頭函數(shù)來導(dǎo)入對應(yīng)的組件,使用起來非常簡單。
使用路由懶加載的方式打包出來的文件結(jié)構(gòu)如下:

我們可以看到比原來的方式多出了3個(gè)js文件,這是因?yàn)槲覀兩厦娲a3個(gè)組件使用了路由懶加載,這3個(gè)js文件只有路由被訪問到了才會去加載,能省下不少的加載時(shí)間
所以我們更推薦使用路由懶加載的方式去加載路由
到此這篇關(guān)于vue 路由懶加載詳情的文章就介紹到這了,更多相關(guān)vue 路由懶加載 內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
Vuepress 搭建帶評論功能的靜態(tài)博客的實(shí)現(xiàn)
這篇文章主要介紹了Vuepress 搭建帶評論功能的靜態(tài)博客的實(shí)現(xiàn),文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2019-02-02
詳解Vue中Computed與watch的用法與區(qū)別
這篇文章主要介紹了Vue中computed和watch的使用與區(qū)別,文中通過示例為大家進(jìn)行了詳細(xì)講解,對Vue感興趣的同學(xué),可以學(xué)習(xí)一下2022-04-04
vue router-view的嵌套顯示實(shí)現(xiàn)
本文主要介紹了vue router-view嵌套顯示,文中通過示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2021-07-07
vue.js或js實(shí)現(xiàn)中文A-Z排序的方法
下面小編就為大家分享一篇vue.js或js實(shí)現(xiàn)中文A-Z排序的方法,具有很好的參考價(jià)值,希望對大家有所幫助。一起跟隨小編過來看看吧2018-03-03
利用Vue2.x開發(fā)實(shí)現(xiàn)JSON樹的方法
這篇文章主要給大家介紹了關(guān)于利用Vue2.x開發(fā)實(shí)現(xiàn)JSON樹的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧。2018-01-01
Vue2 監(jiān)聽屬性改變watch的實(shí)例代碼
今天小編就為大家分享一篇Vue2 監(jiān)聽屬性改變watch的實(shí)例代碼,具有很好的參考價(jià)值,希望對大家有所幫助。一起跟隨小編過來看看吧2018-08-08

