Vue學(xué)習(xí)-VueRouter路由基礎(chǔ)
一、VueRouter
1、說(shuō)明
用 Vue.js + Vue Router 創(chuàng)建單頁(yè)應(yīng)用,感覺(jué)很自然:使用 Vue.js ,我們已經(jīng)可以通過(guò)組合組件來(lái)組成應(yīng)用程序,當(dāng)你要把 Vue Router 添加進(jìn)來(lái),我們需要做的是,將組件 (components) 映射到路由 (routes),然后告訴 Vue Router 在哪里渲染它們。路由本質(zhì)上就是超鏈接。
2、選中路由的渲染:
(1)、router-link-exact-active類
當(dāng)路由到哪里時(shí),該類名就添加到對(duì)應(yīng)的路由標(biāo)簽上。
比如:當(dāng)點(diǎn)擊About時(shí),路由就跳轉(zhuǎn)到About對(duì)應(yīng)的頁(yè)面
(2)、router-link-active類
路由中,子路由的path設(shè)置(比如:http://localhost/home)包含了父路由的path設(shè)置(比如:http://localhost/),那么點(diǎn)擊子路由的時(shí)候,給子路由添加router-link-active類時(shí),父路由也有router-link-active類。也就是當(dāng)點(diǎn)擊(http://localhost/home)路由后,兩個(gè)路由都有被選中的效果。
3、基本工作原理

在vue中的html部分引入router-link(與a原理類似),to屬性就是要跳轉(zhuǎn)的vue組件,而router-view就負(fù)責(zé)展現(xiàn)當(dāng)前路由所指向的內(nèi)容,使得單頁(yè)面也能達(dá)到頁(yè)面跳轉(zhuǎn)的效果!
二、實(shí)戰(zhàn)
1、創(chuàng)建一個(gè)帶router的vue項(xiàng)目

2、打開(kāi)項(xiàng)目中的src/router/index.js文件
可以看到項(xiàng)目已經(jīng)自動(dòng)生成了兩個(gè)路由,一個(gè)是主頁(yè)home,一個(gè)是about界面。路徑分別為 '/' 和 '/about' 。

打開(kāi)根目錄的main.js,可以看到在main.js引入了路由,所以在所有組件中都可以使用路由了。

3、在瀏覽器中打開(kāi)項(xiàng)目
可以看到Home和About兩個(gè)路由導(dǎo)航。

4、新建路由
寫(xiě)一個(gè)類似淘寶的路由導(dǎo)航,包括:主頁(yè)、消息、購(gòu)物車和我的四部分。
新建四個(gè)vue文件,對(duì)應(yīng)四個(gè)路由。

配置路由index.js文件
import Vue from 'vue'
import VueRouter from 'vue-router'
import Home from '../views/Home.vue'
Vue.use(VueRouter)
const routes = [
{
path: '/',
name: 'Home',
component: Home
},
{
path: '/message',
name: 'Message',
component: () => import(/* webpackChunkName: "about" */ '../views/Message.vue')
},
{
path: '/goodcar',
name: 'GoodCar',
component: () => import(/* webpackChunkName: "about" */ '../views/GoodCar.vue')
},
{
path: '/me',
name: 'Me',
component: () => import(/* webpackChunkName: "about" */ '../views/Me.vue')
}
]
const router = new VueRouter({
routes
})
export default router
在App.vue中配置導(dǎo)航欄
<template>
<div id="app">
<div id="nav">
<router-link to="/">主頁(yè)</router-link>
<router-link to="/message">消息</router-link>
<router-link to="/goodcar">購(gòu)物車</router-link>
<router-link to="/me">我的</router-link>
</div>
<router-view/>
</div>
</template>
<style>
#app {
font-family: Avenir, Helvetica, Arial, sans-serif;
-webkit-font-smoothing: antialiased;
-moz-osx-font-smoothing: grayscale;
text-align: center;
color: #2c3e50;
}
#nav {
padding: 30px;
margin: 0 auto;
width: 30%;
display: flex;
justify-content: space-around;
}
#nav a {
font-weight: bold;
color: #2c3e50;
text-decoration: none;
}
#nav a.router-link-exact-active {
color: #42b983;
}
</style>
結(jié)果:

這樣我們就了解了路由的基本概念及其配置以及它的功能。
到此這篇關(guān)于Vue學(xué)習(xí)-VueRouter路由基礎(chǔ)的文章就介紹到這了,更多相關(guān)VueRouter路由基礎(chǔ)內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
vue-router跳轉(zhuǎn)時(shí)打開(kāi)新頁(yè)面的兩種方法
這篇文章主要給大家介紹了關(guān)于vue-router跳轉(zhuǎn)時(shí)打開(kāi)新頁(yè)面的相關(guān)資料,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家學(xué)習(xí)或者使用vue-router具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2019-07-07
vue項(xiàng)目中公用footer組件底部位置的適配問(wèn)題
footer為公用組件,其他頁(yè)面都需要引入。接下來(lái)通過(guò)本文給大家分享vue項(xiàng)目中公用footer組件底部位置的適配問(wèn)題,需要的朋友可以參考下2018-05-05
vue實(shí)現(xiàn)GitHub的第三方授權(quán)方法示例
本文主要介紹了vue實(shí)現(xiàn)GitHub的第三方授權(quán),文中通過(guò)示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2021-11-11
vue3.0公共組件自動(dòng)導(dǎo)入的方法實(shí)例
這篇文章主要給大家介紹了關(guān)于vue3.0公共組件自動(dòng)導(dǎo)入的相關(guān)資料,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2021-04-04
復(fù)刻畫(huà)龍產(chǎn)品vue實(shí)現(xiàn)新春氣泡兔
這篇文章主要為大家介紹了復(fù)刻畫(huà)龍產(chǎn)品之使用vue實(shí)現(xiàn)新春氣泡兔示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2023-01-01
Vue.js 2.0和Cordova開(kāi)發(fā)webApp環(huán)境搭建方法
下面小編就為大家分享一篇Vue.js 2.0和Cordova開(kāi)發(fā)webApp環(huán)境搭建方法,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2018-02-02
electron-vue中報(bào)錯(cuò)Cannot?use?import?statement?outside?a?m
Electron 是一個(gè)使用 JavaScript、HTML 和 CSS 構(gòu)建桌面應(yīng)用程序的框架,下面這篇文章主要給大家介紹了關(guān)于electron-vue中報(bào)錯(cuò)Cannot?use?import?statement?outside?a?module的解決方案,需要的朋友可以參考下2023-02-02
Vue3發(fā)送post請(qǐng)求出現(xiàn)400?Bad?Request報(bào)錯(cuò)的解決辦法
這篇文章主要給大家介紹了關(guān)于Vue3發(fā)送post請(qǐng)求出現(xiàn)400?Bad?Request報(bào)錯(cuò)的解決辦法,文中通過(guò)實(shí)例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2023-02-02
vue?parseHTML?函數(shù)拿到返回值后的處理源碼解析
這篇文章主要為大家介紹了vue?parseHTML?函數(shù)拿到返回值后的處理源碼解析,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2022-07-07
Vue3+Element?Plus的項(xiàng)目搭建過(guò)程詳解
這篇文章主要為大家介紹了Vue3+Element?Plus的項(xiàng)目搭建過(guò)程詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2023-08-08

