设为首页 加入收藏

TOP

vue-router再学习(一)
2019-09-17 19:09:22 】 浏览:74
Tags:vue-router 学习

vue路由:

1:动态路由配置

import Vue from 'vue'
import Router from 'vue-router'
import Index from '@/view/index'
import Layout from '@/view/layout'
import Home from '@/view/home'
import error from '@/view/error'
import p404 from '@/view/404'
import p505 from '@/view/505'
import Login from '@/login'
import AddGood from '@/view/table/addGoods'

Vue.use(Router)

const router = new Router({
  routes: [
    {path:'/',redirect:'/home'},
    {
      path: '/',
      name: 'Index',
      component: Index,
      children:[
        {
          path: 'home',
          name: 'Home',
          component: Home,
          meta:{
            requireLogin:true
          },
        },
        {
          path: 'add',
          name: 'AddGood',
          component: AddGood,
          meta:{
            requireLogin:true
          },
        }
      ]
    },
    {
      path: '/login',
      name: 'Login',
      component: Login
    },
    {
      path: '/error',
      name: 'error',
      component: error,
      children:[
        {
          path: '404',
          name: '404',
          component: p404,
        },
        {
          path: '505',
          name: '505',
          component: p505,
        }

      ]
    }
  ]
})
// 路由拦截
router.beforeEach((to, from, next) => {
  if (to.matched.some(res => res.meta.requireLogin)) {
    // 判断是否需要登录权限
    if (window.localStorage.getItem("username")) {
      next();
    } else {
      // 没登录则跳转到登录界面
      console.log("to login");

      next({
        path: "/login"
      });
    }
  } else {
    next();
  }
});
export default router;

2:响应路由参数的变化:

例如从/user/foo导航到/user/bar,原来的组件会被复用,
这种方式获取url上的参数可以watch来监视$route对象来获取

3:嵌套路由:要在嵌套的出口中渲染组件,需要在 VueRouter 的参数中使用 children 配置:

const router = new VueRouter({
  routes: [
    { path: '/user/:id', component: User,
      children: [
        {
          // 当 /user/:id/profile 匹配成功,
          // UserProfile 会被渲染在 User 的 <router-view> 中
          path: 'profile',
          component: UserProfile
        },
        {
          // 当 /user/:id/posts 匹配成功
          // UserPosts 会被渲染在 User 的 <router-view> 中
          path: 'posts',
          component: UserPosts
        }
      ]
    }
  ]
})

路由可以层层嵌套;要注意,以 / 开头的嵌套路径会被当作根路径。 这让你充分的使用嵌套组件而无须设置嵌套的路径。

当你访问一个没有匹配的路由的时候,如果要渲染点什么东西,可以提供一个空的子路由

const router = new VueRouter({
  routes: [
    {
      path: '/user/:id', component: User,
      children: [
        // 当 /user/:id 匹配成功,
        // UserHome 会被渲染在 User 的 <router-view> 中
        { path: '', component: UserHome },

        // ...其他子路由
      ]
    }
  ]
})

### 4:编程式导航:router.push(location, onComplete?, onAbort?)

除了使用 <router-link> 创建 a 标签来定义导航链接,我们还可以借助 router 的实例方法,通过编写代码来实现。
注意:在 Vue 实例内部,你可以通过 $router 访问路由实例。因此你可以调用 this.$router.push
想要导航到不同的 URL,则使用 router.push 方法。这个方法会向 history 栈添加一个新的记录,所以,当用户点击浏览器后退按钮时,则回到之前的 URL。
当你点击 <router-link> 时,这个方法会在内部调用,所以说,点击 <router-link :to="..."> 等同于调用 router.push(...)。

该方法的参数可以是一个字符串路径,或者一个描述地址的对象。例如
// 字符串:router.push('home')
// 对象:router.push({ path: 'home' })

// 命名的路由:router.push({ name: 'user', params: { userId: '123' }})
这里的命名是指在route.JS里面定义动态路由配置name,参考第一点

带查询参数:变成 /register?plan=private
router.push({ path: 'register', query: { plan: 'private' }})
注意:如果提供了path,则params会被忽略,因此不能这样写:
this.$router.push({ path: 'register', params: { plan: 'private' }})这样是不能解析参数出来的。
正确的写法应该是这样:
this.$router.push({path:`user/${userID}`})  ===> /user/123,
this.router.push({path:'user',params:{userID}}) ====> /user,不能解析出userID
注意跟命名路由的区别:
this.$router.push({name:'user',params:{userId: 123}})===> /user/123

用于记住导航链接:在 2.2.0+,可选的在 router.pushrouter.replace 中提供 onCompleteonAbort 回调作为第二个和第三个参数。这些回调将会在导航成功完成 (在所有的异步钩子被解析之后) 或终止 (导航到相同的路由、或在当前导航完成之前导航到另一个不同的路由) 的时候进行相应的调用。

注意: 如果目的地和当前路由相同,只有参数发生了改变 (比如从一个用户资料到

首页 上一页 1 2 3 下一页 尾页 1/3/3
】【打印繁体】【投稿】【收藏】 【推荐】【举报】【评论】 【关闭】 【返回顶部
上一篇Ajax实现附件上传 下一篇js中数字直接点方法会报错,如1.t..

最新文章

热门文章

Hot 文章

Python

C 语言

C++基础

大数据基础

linux编程基础

C/C++面试题目