vue中組件<router-view>使用方法詳解
前言
<router-view>
是 Vue Router 提供的一個用于動態(tài)顯示匹配到的組件內(nèi)容的組件。在單頁面應(yīng)用中,頁面的切換是通過路由的變化來實(shí)現(xiàn)的,而 <router-view>
負(fù)責(zé)根據(jù)當(dāng)前路由匹配到的組件渲染相應(yīng)的內(nèi)容。
下面是 <router-view>
的一些使用詳解:
基本使用:
在主模板中使用 <router-view>
標(biāo)簽,它會根據(jù)當(dāng)前路由的匹配情況動態(tài)渲染對應(yīng)的組件。
<template> <div id="app"> <router-view></router-view> </div> </template> <script> export default { // 組件的其他配置 }; </script>
嵌套路由:
<router-view>
可以嵌套使用,以支持嵌套路由的場景。在父組件中使用多個 <router-view>
標(biāo)簽,每個標(biāo)簽對應(yīng)一個具體的嵌套路由。
<template> <div> <header>Header</header> <router-view></router-view> <footer>Footer</footer> </div> </template>
命名視圖:
使用 <router-view>
標(biāo)簽時(shí),你還可以為其指定 name
屬性,從而支持命名視圖,這在同時(shí)展示多個視圖的情況下很有用。
<template> <div> <router-view name="header"></router-view> <router-view></router-view> <router-view name="footer"></router-view> </div> </template>
在路由配置中,對應(yīng)的路由定義也需要添加 components
字段:
const routes = [ { path: '/', components: { default: Home, header: Header, footer: Footer } } ];
動態(tài)組件:
<router-view>
也支持渲染動態(tài)組件。你可以通過在路由配置中使用 component
字段,將組件與路由進(jìn)行關(guān)聯(lián)。
const routes = [ { path: '/dynamic', component: () => import('./DynamicComponent.vue') } ];
在模板中:
<template> <div> <router-view></router-view> </div> </template>
過渡效果:
如果你希望在切換路由時(shí)添加過渡效果,可以在 <router-view>
外層包裹 <transition>
標(biāo)簽。
<template> <div> <transition name="fade" mode="out-in"> <router-view></router-view> </transition> </div> </template> <style> .fade-enter-active, .fade-leave-active { transition: opacity 0.5s; } .fade-enter, .fade-leave-to { opacity: 0; } </style>
在上述例子中,路由切換時(shí)會產(chǎn)生淡入淡出的過渡效果。
這些是 <router-view>
的一些基本用法和高級特性。在 Vue Router 中,<router-view>
是實(shí)現(xiàn)動態(tài)路由渲染的核心組件,通過合理配置路由和使用 <router-view>
,你可以構(gòu)建出強(qiáng)大且靈活的單頁面應(yīng)用。
附:vue使用router-view調(diào)用頁面
在項(xiàng)目中,需要在其中一個頁面,調(diào)用很多其他頁面的表單,所以使用router來實(shí)現(xiàn)頁面的調(diào)用。
vue-router有傳遞參數(shù)的兩種方式,get和post。
1.get方式
頁面跳轉(zhuǎn)
this.$router.push({path:'/xxx',query:{id:1}});//類似get傳參,通過URL傳遞參數(shù)
新頁面接收參數(shù)
this.$route.query.id
2.post方式
頁面跳轉(zhuǎn)
//由于動態(tài)路由也是傳遞params的,所以在 this.$router.push() 方法中 path不能和params一起使用 //否則params將無效。 //需要用name來指定頁面。 this.$router.push({name:'page2',params:{id:1}});//類似post傳參
新頁面接收參數(shù)
this.$route.params.id
注意:在頁面進(jìn)行刷新的時(shí)候經(jīng)常會遇到參數(shù)變了,但是新頁面接受的參數(shù)沒有變化。這種問題可以通過加watch解決。
watch: { '$route'(to, from){ //在這里重新刷新一下 this.getParams(); } }
總結(jié)
到此這篇關(guān)于vue中組件<router-view>使用方法的文章就介紹到這了,更多相關(guān)vue中<router-view>使用內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
Vue實(shí)現(xiàn)PopupWindow組件詳解
這篇文章主要為大家詳細(xì)介紹了Vue實(shí)現(xiàn)PopupWindow組件,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2018-04-04element-ui?table表格底部合計(jì)自定義配置過程
這篇文章主要介紹了element-ui?table表格底部合計(jì)自定義配置過程,具有很好的參考價(jià)值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教2023-10-10Vue.js綁定HTML class數(shù)組語法錯誤的原因分析
Vue.js綁定HTML class數(shù)組語法錯誤有哪些原因?qū)е碌哪?,該如何解決呢?下面小編給大家分享Vue.js綁定HTML class數(shù)組語法錯誤的原因分析,感興趣的朋友一起看看吧2016-10-10vue通過子組件修改父組件prop的多種實(shí)現(xiàn)方式
這篇文章主要介紹了vue通過子組件修改父組件prop的幾種實(shí)現(xiàn)方式,比較常用的方式是通過Prop單向傳遞的規(guī)則,需要的朋友可以參考下2021-09-09vue-cli項(xiàng)目優(yōu)化方法- 縮短首屏加載時(shí)間
這篇文章主要介紹了vue-cli項(xiàng)目優(yōu)化 縮短首屏加載時(shí)間,需要的朋友可以參考下2018-04-04Vue中關(guān)于computed計(jì)算屬性的妙用
這篇文章主要介紹了Vue中關(guān)于computed計(jì)算屬性的妙用,具有很好的參考價(jià)值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2022-11-11uniapp-vue3-彈出選擇組件wo-pop-selector使用示例
wo-pop-selector彈出選擇組件采用uniapp-vue3實(shí)現(xiàn), 支持H5、微信小程序,本文給大家介紹uniapp-vue3-彈出選擇組件wo-pop-selector及使用示例,感興趣的朋友一起看看吧2023-10-10