04.动态路由(路由传参)、history模式(与带#的hash

2020-07-04  本文已影响0人  小二的学习日记

动态路由

1.编写点击跳转页面的逻辑(编程式导航、传参)

//===>src/views/Film/Nowplaying.vue
<template>
  <div>
    nowplaying
    <ul>
      <li v-for="data in datalist" :key="data" @click="handleChangePage(data)">{{data}}</li>
    </ul>
  </div>
</template>

<script>
export default {
  data() {
    return {
      datalist: ["1111", "2222", "3333"]
    };
  },
  methods: {
    handleChangePage(id) {
      console.log(id);
      //编程式导航
      this.$router.push(`/detail/${id}`);
    }
  }
};
</script>

2.编写detail页面的跳转规则

//===>src/router/index.js
...
import Detail from '@/views/Film/Detail'

Vue.use(VueRouter)

const routes = [
  {
    path: '/film',
   ...
    ]
  },
...
  {
    path: '/detail/:id',
    component: Detail
  },
 ...
]
...

3.编写新的页面

//===>src/views/Film/Detail.vue
<template>
  <div>detail</div>
</template>
<script>
export default {
  mounted() {
    console.log("要id获取详情信息", this.$route.params.id);
  }
};
</script>
点击
带参数的跳转

history模式

路由守卫

全局守卫

1.在路由文件配置全局守卫

//===>src/router/index.js
import Vue from 'vue'
import VueRouter from 'vue-router'
import Home from '../views/Home.vue'
import Film from '@/views/Film'
import Cinema from '@/views/Cinema'
import Center from '@/views/Center'
import Login from '@/views/Login'
import Nowplaying from '@/views/Film/Nowplaying'
import Comingsoon from '@/views/Film/Comingsoon'
import Detail from '@/views/Film/Detail'

Vue.use(VueRouter)

const auth = {
  isLogin() {
    return false
  }
}

const routes = [
  {
    path: '/film',
    component: Film,
    children: [
      {
        path: 'nowplaying',
        component: Nowplaying
      }, {
        path: 'comingsoon',
        component: Comingsoon
      }, {
        path: '',
        redirect: '/film/nowplaying'
      }
    ]
  },
  {
    path: '/cinema',
    component: Cinema
  },
  {
    path: '/detail/:id',
    name: 'kerwindetail',
    component: Detail
  },
  {
    path: '/center',
    component: Center
  },
  {
    path: '/login',
    component: Login
  },
  {
    path: '*',
    component: Film
  }
]

const router = new VueRouter({
  mode: 'history',
  base: process.env.BASE_URL,
  routes
})
// 全局守卫
router.beforeEach((to, from, next) => {
  console.log("盘查");
  if (to.path === '/center') {
    if (auth.isLogin()) {
      next()
    } else {
      next('/login')
    }
  } else {
    next()
  }
})
export default router

2.编写Login组件

//===>src/views/Login.vue
<template>
    <div>
        Login
    </div>
</template>
image.png
局部守卫

1.注释掉全局守卫

//===>src/router/index.js
...
// 全局守卫
// router.beforeEach((to, from, next) => {
//   console.log("盘查");
//   if (to.path === '/center') {
//     if (auth.isLogin()) {
//       next()
//     } else {
//       next('/login')
//     }
//   } else {
//     next()
//   }
// })
...

2.在Center页面编写局部守卫

//===>src/views/Center.vue
<template>
  <div>Center</div>
</template>

<script>
export default {
  beforeRouteEnter(to, from, next) {
    console.log("局部盘查");
    if (false) {
      next();
    } else {
      next("/login");
    }
  }
};
</script>

<style lang="sass" scoped>

</style>

运行结果和全局守卫一样。

上一篇 下一篇

猜你喜欢

热点阅读