亚洲精品久久久中文字幕-亚洲精品久久片久久-亚洲精品久久青草-亚洲精品久久婷婷爱久久婷婷-亚洲精品久久午夜香蕉

您的位置:首頁技術(shù)文章
文章詳情頁

vue 基于abstract 路由模式 實(shí)現(xiàn)頁面內(nèi)嵌的示例代碼

瀏覽:3日期:2022-10-19 15:42:12
abstract 路由模式

abstract 是vue路由中的第三種模式,本身是用來在不支持瀏覽器API的環(huán)境中,充當(dāng)fallback,而不論是hash還是history模式都會(huì)對(duì)瀏覽器上的url產(chǎn)生作用,本文要實(shí)現(xiàn)的功能就是在已存在的路由頁面中內(nèi)嵌其他的路由頁面,而保持在瀏覽器當(dāng)中依舊顯示當(dāng)前頁面的路由path,這就利用到了abstract這種與瀏覽器分離的路由模式。

路由示例

export const routes = [ { path: '/', redirect: 'abstract-route', }, { path: '/embed-route', name: 'embedded', component: () => import(/* webpackChunkName: 'embed' */ '../views/embed.vue'), }, { path: '/abstract-route', name: 'abstract', component: () => import(/* webpackChunkName: 'abstract' */ '../views/abstract.vue'), },];const router = new VueRouter({ mode: 'history', base: process.env.BASE_URL, routes,});

本次示例有兩個(gè)路由,分別為abstract,embedded,其中abstract視圖上展開一個(gè)抽屜,抽屜當(dāng)中顯示embedded的視圖。即:

<template> <div> <RouterDrawer :visible.sync='visible' :path='{ name: ’embedded’ }' size='50%' ></RouterDrawer> <el-button @click='visible = true'>open drawer</el-button> </div></template>// embedded views<template> <div> embedded views </div></template>

vue 基于abstract 路由模式 實(shí)現(xiàn)頁面內(nèi)嵌的示例代碼

router-drawer 封裝

當(dāng)前項(xiàng)目默認(rèn)是history 的路由模式,因此在進(jìn)入abstract頁面時(shí),瀏覽器Url為http://127.0.0.1:8010/abstract-route,而router-drawer要做的是在此基礎(chǔ)上,重新實(shí)例化一個(gè)abstract模式的路由,然后在組件當(dāng)中利用<router-view />去掛載要被內(nèi)嵌的目標(biāo)頁面。即:

<template> <el-drawer :visible.sync='visible' v-bind='$attrs' :before-close='handleClose' > <router-view /> </el-drawer></template><script>import { routes } from '../router/index';import VueRouter from 'vue-router';export default { name: 'router-drawer', props: { path: { type: Object, required: true, }, visible: { type: Boolean, required: true, default: false, }, }, // 此處實(shí)例化一個(gè)新的router來配合當(dāng)前頁面的router-view router: new VueRouter({ mode: 'abstract', base: '/', routes, }), methods: { handleClose() { this.$emit('update:visible', false); }, }, mounted() { console.log('drawer router', this.$router); this.$router.push(this.path); },};</script>

通過打印日志可以得出兩個(gè)實(shí)例化的路由:

vue 基于abstract 路由模式 實(shí)現(xiàn)頁面內(nèi)嵌的示例代碼

這樣即可實(shí)現(xiàn)在不改變當(dāng)前頁面path的前提下加載其他路由中的views了。

代碼示例

以上就是vue 基于abstract 路由模式 實(shí)現(xiàn)頁面內(nèi)嵌的示例代碼的詳細(xì)內(nèi)容,更多關(guān)于vue 實(shí)現(xiàn)頁面內(nèi)嵌的資料請(qǐng)關(guān)注好吧啦網(wǎng)其它相關(guān)文章!

標(biāo)簽: Vue
相關(guān)文章:
主站蜘蛛池模板: 欧美在线一区二区三区欧美 | 男人综合网 | 91精品国产91久久久久久最新 | 成人自拍视频 | 中文字幕专区高清在线观看 | 中文视频在线 | 97视频在线观看视频在线精品 | 国产日韩一区二区三区在线播放 | 在线久综合色手机在线播放 | 久久天堂夜夜一本婷婷麻豆 | 中文无码日韩欧免费视频 | 99爱精品视频 | 九九视频免费在线 | 在线免费观看黄色片 | 久久久久久久久a免费 | 日本亚洲乱码中文字幕影院 | 色香婷婷 | 青草香蕉精品视频在线观看 | 日韩在线毛片 | 北条麻妃一区二区三区 | 免费黄视频在线观看 | 黄色欧美网站 | 99在线国产| 亚洲欧美一区二区三区久久 | 在线免费看黄 | 亚洲绝美精品一区二区 | 91在线一区二区三区 | 香蕉视频观看 | 日本成人一区二区三区 | 国产精品视频久 | 国产精品久久久久久久久久久搜索 | 国产激情视频在线 | 国产成人欧美一区二区三区的 | 永久免费在线播放 | 国产一区二区免费视频 | 日韩一区精品视频在线看 | 91桃色视频在线观看 | 国产综合视频在线观看一区 | 国产伦子一区二区三区 | 毛片综合 | 香蕉视频网站免费观视频 |