10分鐘快速上手VueRouter4.x教程
寫(xiě)在前面
Vue Router是Vue團(tuán)隊(duì)的研發(fā)的一款與Vue.js核心深度集成的一款路由插件,使Vue構(gòu)建單頁(yè)面程序變得非常的簡(jiǎn)單;Vue Router目前最新版本是4.X,也是Vue3推薦使用的版本,這篇文章我們就來(lái)學(xué)習(xí)一下Vue Router4.X。
URL.hash與History
Vue Router中存在兩種history(記錄歷史路由),分別是URL.hash和HTML5中提供的History兩種。
hash歷史記錄對(duì)于沒(méi)有主機(jī)的Web應(yīng)用程序(例如file://),或當(dāng)配置服務(wù)器不能處理任意的URL時(shí)非常有用,但是hash的SEO非常差勁;
History歷史是HTML5中新增的,對(duì)于IE來(lái)說(shuō)不是很友好,但是Vue3都放棄IE了,你也就不用考慮IE了;這種方式是目前最常見(jiàn)的一種方式,但是應(yīng)用程序必須通過(guò)http協(xié)議被提供服務(wù)。
安裝與使用流程
首先我們安裝Vue Router,命令如下:
npm i vue-router
然后在main.js中寫(xiě)入如下代碼:
import { createApp } from 'vue'
import App from './App.vue'
// 1 引入 createRouter
import { createRouter, createWebHistory } from 'vue-router'
// 2 定義路由映射表
const routes = [
/* more router */
]
// 3 創(chuàng)建路由實(shí)例,并傳遞對(duì)應(yīng)配置
const router = createRouter({
// history 模式 這里使用createWebHistory
history: createWebHistory(),
// 傳遞路由映射表
routes
})
createApp(App).use(router).mount('#app')上面的代碼中的routes如果多的話,可以定義一個(gè)router.js文件,將其進(jìn)行抽離,示例代碼如下:
router.js
export default [ /* more router */ ]
main.js
import { createApp } from 'vue'
import App from './App.vue'
// 2 引入路由映射表
import routes from './router'
// 1 引入 createRouter
import { createRouter, createWebHistory } from 'vue-router'
// 3 創(chuàng)建路由實(shí)例,并傳遞對(duì)應(yīng)配置
const router = createRouter({
// history 模式 這里使用createWebHistory
history: createWebHistory(),
// 傳遞路由映射表
routes
})
createApp(App).use(router).mount('#app')或者**直接在****router.js中直接導(dǎo)出一個(gè)路由實(shí)例,在main.js**中使用即可(這種方式更常用)。
router-link和router-view
router-link
<router-link>是Vue提供的自定義組件,用于創(chuàng)建鏈接,在Vue中并沒(méi)有使用原生的<a>,因?yàn)?code><a>改變URL后會(huì)重新加載頁(yè)面而<router-link>不會(huì);關(guān)于<router-link>組件的細(xì)節(jié)支持哪些屬性,可以參考文檔。
router-view
<router-view>組件用于與URL對(duì)應(yīng)的組件,例如下面這段代碼:
<template>
<router-link to="/hello"
><img alt="Vue logo" src="./assets/logo.png"
/></router-link>
<router-view></router-view>
</template>然后我們的router.js的代碼如下:
import RootComponent from './components/root.vue'
export default [
{
path: '/',
// 引入組件
component: RootComponent
},
{
path: '/hello',
// 路由懶加載引入組件
component: () => import('./components/HelloWorld.vue')
}
]關(guān)于其他配置項(xiàng),可以參考文檔。
代碼運(yùn)行結(jié)果如下所示:

路由懶加載
當(dāng)我們的應(yīng)用越來(lái)越大時(shí),打包后的JavaScript代碼也會(huì)特別的大,這個(gè)時(shí)候需要我們將整個(gè)應(yīng)用拆分為不同的塊,而Vue Router就支持這個(gè)功能,我們只需要使用動(dòng)態(tài)導(dǎo)入替換靜態(tài)導(dǎo)入即可,就比如上面那段代碼:
component: () => import('./components/HelloWorld.vue')然后打包(webpack、Vite)工具就會(huì)將這些動(dòng)態(tài)導(dǎo)入的組件單獨(dú)打包,如下圖所示:

動(dòng)態(tài)路由
VueRouter允許我們動(dòng)態(tài)的去設(shè)置路由匹配規(guī)則,例如我們現(xiàn)在有一個(gè)User組件,組件的內(nèi)容會(huì)根據(jù)不同的ID展示不同的內(nèi)容,設(shè)置方法只需要通過(guò):參數(shù)名的形式去設(shè)置即可。
例如:
{
path: '/user/:id',
component: () => import('@/components/User')
}在模板中跳轉(zhuǎn)如下:
<router-link to="/user/10010"></router-link>
或者通過(guò)useRouter這個(gè)hook提供的push方法,例如:
import { useRouter } from 'vue-router'
const {push} = useRouter()
push({
path: '/user',
params: { id: 10010 }
})
// 或者
let id = 10010
push('/user/' + id)獲取路由地址可以通過(guò)useRoute這個(gè)hook,用法與useRouter一致。
匹配所有路由
VueRouter的動(dòng)態(tài)路由允許我們匹配哪些沒(méi)有匹配到的路由,示例代碼如下:
{
path: '/:pathMatch(.*)',
component: () => import('./components/Page404.vue'),
},當(dāng)前面的路由匹配未成功時(shí),就會(huì)匹配這個(gè)路由。
路由嵌套
現(xiàn)在我們有一個(gè)需求,就是在HelloWorld組件下存兩個(gè)組件,需要切換著兩個(gè)組件。
這個(gè)時(shí)候路由嵌套的就發(fā)揮作用了,其實(shí)路由嵌套比較簡(jiǎn)單,就是通過(guò)路由配置中的一個(gè)children屬性來(lái)實(shí)現(xiàn),示例代碼如下:
HelloWorld.vue
<template>
<h1>Hello World</h1>
<div
style="
display: flex;
justify-content: space-between;
width: 240px;
margin: 0 auto;
"
>
<router-link to="about">about</router-link>
<router-link to="user">user</router-link>
</div>
<router-view></router-view>
</template>router.js
{
path: '/hello',
// 路由懶加載引入組件
component: () => import('./components/HelloWorld.vue'),
children: [
{
path: 'about',
component: () => import('./components/about.vue'),
},
{
path: 'user',
component: () => import('./components/user.vue'),
},
],
},子組件比較簡(jiǎn)單,只有一個(gè)<h1>標(biāo)簽,最終效果如下:

寫(xiě)在最后
到此這篇關(guān)于10分鐘快速上手VueRouter4.x教程的文章就介紹到這了,更多相關(guān)VueRouter4.x入門內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
vue一個(gè)頁(yè)面實(shí)現(xiàn)音樂(lè)播放器的示例
這篇文章主要介紹了vue一個(gè)頁(yè)面實(shí)現(xiàn)音樂(lè)播放器的示例,小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2018-02-02
通過(guò)html文件來(lái)使用Vue的單文件組件形式詳解
這篇文章主要介紹了通過(guò)html文件來(lái)使用Vue的單文件組件形式詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2023-05-05
Vue中使一個(gè)div鋪滿全屏的實(shí)現(xiàn)
最近在項(xiàng)目開(kāi)發(fā)中,就遇到了這個(gè)問(wèn)題,Vue中如何使一個(gè)div鋪滿全屏,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2024-07-07
Vue Axios異步與數(shù)據(jù)類型轉(zhuǎn)換問(wèn)題淺析
總的來(lái)說(shuō)這并不是一道難題,那為什么要拿出這道題介紹?拿出這道題真正想要傳達(dá)的是解題的思路,以及不斷優(yōu)化探尋最優(yōu)解的過(guò)程。希望通過(guò)這道題能給你帶來(lái)一種解題優(yōu)化的思路,Axios是一個(gè)開(kāi)源的可以用在瀏覽器端和Node JS的異步通信框架,主要作用就是實(shí)現(xiàn)AJAX異步通信2023-01-01
vue3選項(xiàng)式api如何監(jiān)控?cái)?shù)組變化
這篇文章主要介紹了vue3選項(xiàng)式api如何監(jiān)控?cái)?shù)組變化問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2024-06-06
vue3中關(guān)于路由hash與History的設(shè)置
這篇文章主要介紹了vue3中關(guān)于路由hash與History的設(shè)置方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2023-04-04

