国产成人精品亚洲777人妖,欧美日韩精品一区视频,最新亚洲国产,国产乱码精品一区二区亚洲

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

vue的路由動(dòng)畫(huà)切換頁(yè)面無(wú)法讀取meta值的bug記錄

瀏覽:33日期:2022-06-10 10:55:12
目錄
  • vue路由動(dòng)畫(huà)切換頁(yè)面無(wú)法讀取meta值的bug
    • 問(wèn)題原因
    • 解決方法
  • vue路由元信息meta
    • 路由元信息
    • 設(shè)置title
    • 權(quán)限校驗(yàn)(例:登錄校驗(yàn))
  • 總結(jié)

    vue路由動(dòng)畫(huà)切換頁(yè)面無(wú)法讀取meta值的bug

    在vue項(xiàng)目的二級(jí)路由中,想要通過(guò)設(shè)置路由表中的meta值,來(lái)判斷頁(yè)面的slide-left 和slide-right的方向。

    對(duì)于從左到右的排列,給routes依次設(shè)為1,2,3,4…的值,使其可以通過(guò)大小來(lái)判斷from和to,并顯示出不同的劃入 / 劃出效果

    {
    ?? ?path: "aaa",
    ?? ?name: "aaa",
    ?? ?component: aaa,
    ?? ?meta:1
    },
    {
    ?? ?path: "bbb",
    ?? ?name: "bbb",
    ?? ?component: bbb,
    ?? ?redirect:"bbb/baba",
    ?? ?meta:2,
    ?? ?children: [
    ?? ?{
    ?? ??? ?path: "baba",
    ?? ??? ?name: "baba",
    ?? ??? ?component: baba
    ?? ?}, {
    ?? ??? ?path: "ccc",
    ?? ??? ?name: "ccc",
    ?? ??? ?component: ccc
    ?? ?}, {
    ?? ??? ?path: "ddd",
    ?? ??? ?name: "ddd",
    ?? ??? ?component: ddd
    ?? ?}, {
    ?? ??? ?path: "eee",
    ?? ??? ?name: "eee",
    ?? ??? ?component: eee
    ?? ?}, {
    ?? ??? ?path: "fff",
    ?? ??? ?name: "fff",
    ?? ??? ?component: fff
    ?? ?}],
    },
    {
    ?? ?path: "ggg",
    ?? ?name: "ggg",
    ?? ?meta:4,
    ?? ?component: ggg
    },
    {
    ?? ?path: "hhh",
    ?? ?name: "hhh",
    ?? ?meta:3,
    ?? ?component: hhh
    },

    然鵝,

    在設(shè)置的過(guò)程中,其中一個(gè)路由始終無(wú)法讀到all這個(gè)路由中的meta:2

    導(dǎo)致切換路由的動(dòng)畫(huà)效果出了問(wèn)題

    問(wèn)題原因

    讀不到的meta的是因?yàn)樵O(shè)置了子路由以及重定向。

    解決方法

    把meta值加在它的子路由上,

    {
    ?? ?path: "bbb",
    ?? ?name: "bbb",
    ?? ?component: bbb,
    ?? ?redirect:"bbb/baba",
    ?? ?//meta:2,
    ?? ?children: [
    ?? ?{
    ?? ??? ?path: "baba",
    ?? ??? ?name: "baba",
    ?? ??? ?component: baba,
    ?? ??? ?meta:2
    ?? ?}, {
    ?? ??? ?path: "ccc",
    ?? ??? ?name: "ccc",
    ?? ??? ?component: ccc
    ?? ?}, {
    ?? ??? ?path: "ddd",
    ?? ??? ?name: "ddd",
    ?? ??? ?component: ddd
    ?? ?}, {
    ?? ??? ?path: "eee",
    ?? ??? ?name: "eee",
    ?? ??? ?component: eee
    ?? ?}, {
    ?? ??? ?path: "fff",
    ?? ??? ?name: "fff",
    ?? ??? ?component: fff
    ?? ?}],
    },

    vue路由元信息meta

    路由元信息

    定義路由的時(shí)候可以配置meta字段。

    那么我們可以利用meta字段來(lái)做什么呢?

    設(shè)置title

    ? ? name: "category",
    ? ? component: () => import("./view/creatBrainStorm/creat/category"),
    ? ? meta: {
    ? ? ? title: "卓腦"
    ? ? }

    我們可以在鉤子函數(shù)router.beforeEach中獲取meta中的title數(shù)據(jù),并設(shè)置為頁(yè)面標(biāo)題。

    router.beforeEach((to, from, next) => {
    ? const title = to.meta && to.meta.title
    ? if (title) {
    ? ? document.title = title
    ? }
    }

    權(quán)限校驗(yàn)(例:登錄校驗(yàn))

    {
    ? ? name: "cart",
    ? ? component: () => import("./view/cart"),
    ? ? meta: {
    ? ? ? title: "購(gòu)物車(chē)",
    ? ? ? requireAuth: true // 當(dāng)有這個(gè)字段的時(shí)候,我們就認(rèn)為這個(gè)路由頁(yè)面是要有登錄權(quán)限的
    ? ? }
    ? }

    檢查meta中元字段:

    if (to.meta.requireAuth) {
    ? ? // 不直接通過(guò)本地緩存進(jìn)行判斷,而是通過(guò)Vuex的屬性狀態(tài)進(jìn)行判斷
    ? ? if (store.state.user.token) {
    ? ? ? next()
    ? ? } else {
    ? ? ? next({
    ? ? ? ? path: "/login",
    ? ? ? ? query: { redirect: to.fullPath }
    ? ? ? })
    ? ? }
    ? } else {
    ? ? next()
    ? }

    總結(jié)

    以上為個(gè)人經(jīng)驗(yàn),希望能給大家一個(gè)參考,也希望大家多多支持。

    標(biāo)簽: JavaScript
    相關(guān)文章:
    主站蜘蛛池模板: 彩票| 右玉县| 凤城市| 黔东| 营口市| 龙州县| 阿拉善右旗| 石河子市| 贺兰县| 扶余县| 武川县| 张家港市| 嵊泗县| 景德镇市| 普陀区| 普兰店市| 湾仔区| 山阳县| 罗田县| 邵东县| 东丰县| 读书| 宝鸡市| 山阳县| 社旗县| 四平市| 澳门| 河西区| 库尔勒市| 北辰区| 潍坊市| 沾化县| 莲花县| 丹棱县| 潼关县| 东海县| 古丈县| 蒙城县| 西林县| 武冈市| 平远县|