Vue中路由的相关知识

1.路由的概念

路由分为后端路由和前端路由。
1.后端路由:由服务器端进行实现,并完成资源的分发。
2.前端路由:依靠hash值(锚链接)的变化进行实现;根据不同的事件来显示不同的页面内容,即事件与事件处理函数之间的对应关系。

2.Vue-Router的使用

步骤:

  1. 引入js文件,vue-router.js需要依赖vue.js文件。
  2. 添加路由链接:是路由中提供的标签,默认会被渲染为a标签,to属性默认被渲染为href属性,to属性的值会被渲染为#开头的hash地址。
  3. 添加路由填充位(路由占位符) -----router-view
  4. 定义路由组件
  5. 配置路由规则并创建路由实例
  6. 将路由挂载到Vue实例中

代码示例:

  <body>
    <!-- 被 vm 实例所控制的区域 -->
    <div id="app">
      <router-link to="/user">User</router-link>
      <router-link to="/register">Register</router-link>

    <!-- 路由占位符 -->
      <router-view></router-view>
    </div>
     <!-- 导入 vue 文件 -->
    <script src="./lib/vue_2.5.22.js"></script>
    <script src="./lib/vue-router_3.0.2.js"></script>
    <script>
      const User = {
        template: '<h1>User 组件</h1>'
      }

      const Register = {
        template: '<h1>Register 组件</h1>'
      }

      // 创建路由实例对象
      const router = new VueRouter({
        // 所有的路由规则
        routes: [
          { path: '/user', component: User },
          { path: '/register', component: Register }
        ]
      })

      // 创建 vm 实例对象
      const vm = new Vue({
        // 指定控制的区域
        el: '#app',
        data: {},
        // 挂载路由实例对象
        // router: router
        router
      })
    </script>

3.嵌套路由

进行路由的时候显示的组件中还有新的子级路由链接以及内容,这就成为路由的嵌套。

<body>
    <!-- 被 vm 实例所控制的区域 -->
    <div id="app">
        <router-link to="/user">User</router-link>
        <router-link to="/register">Register</router-link>

        <!-- 路由占位符 -->
        <router-view></router-view>
    </div>
    <script>
        const User = {
            template: '<h1>User 组件</h1>'
        }
        const Register = {
            template: `<div>
          <h1>Register 组件</h1>
          <hr/>

          <!-- 子路由链接 -->
          <router-link to="/register/tab1">tab1</router-link>
          <router-link to="/register/tab2">tab2</router-link>

          <!-- 子路由的占位符 -->
          <router-view />
        <div>`
        }
        const Tab1 = {
            template: '<h3>tab1 子组件</h3>'
        }
        const Tab2 = {
            template: '<h3>tab2 子组件</h3>'
        }
        // 创建路由实例对象
        const router = new VueRouter({
            // 所有的路由规则
            routes: [{
                    path: '/',
                    redirect: '/user'
                }, {
                    path: '/user',
                    component: User
                },
                // children 数组表示子路由规则
                {
                    path: '/register',
                    redirect: '/register/tab1',
                    component: Register,
                    children: [{
                        path: '/register/tab1',
                        component: Tab1
                    }, {
                        path: '/register/tab2',
                        component: Tab2
                    }]
                }
            ]
        })
        // 创建 vm 实例对象
        const vm = new Vue({
            // 指定控制的区域
            el: '#app',
            data: {},
            // 挂载路由实例对象
            // router: router
            router
        })
    </script>

4.动态路由匹配

  1. 可以使用$router.params的方法获取相应的参数。
  2. 通过props获取参数,props为true、对象、函数时代表不同的含义。
  3. props为true时 在子组件中可以通过props属性直接获取相应的传递数据。 形如:[‘id’]
  4. props为对象时,子组件中可以获取传递对象中的对应属性值。形如:[‘name’,‘age’]
  5. props为函数时,子组件中可以获取所有传递过去的值。形如:[‘id’, ‘uname’, ‘age’]
  <!-- 被 vm 实例所控制的区域 -->
    <div id="app">
      <router-link to="/user/1">User1</router-link>
      <router-link to="/user/2">User2</router-link>
      <router-link to="/user/3">User3</router-link>
      <router-link to="/register">Register</router-link>

      <!-- 路由占位符 -->
      <router-view></router-view>
    </div>

    <script>
      const User = {
        props: ['id', 'uname', 'age'],
        template: '<h1>User 组件 -- 用户id为: {{id}} -- 姓名为:{{uname}} -- 年龄为:{{age}}</h1>'
      }

      const Register = {
        template: '<h1>Register 组件</h1>'
      }

      // 创建路由实例对象
      const router = new VueRouter({
        // 所有的路由规则
        routes: [
          { path: '/', redirect: '/user' },
          {
            path: '/user/:id',
            component: User,
            props: route => ({ uname: 'zs', age: 20, id: route.params.id })
          },
          { path: '/register', component: Register }
        ]
      })

      // 创建 vm 实例对象
      const vm = new Vue({
        // 指定控制的区域
        el: '#app',
        data: {},
        // 挂载路由实例对象
        // router: router
        router
      })
    </script>

5.命名路由

在命名规则中通过name属性给对应路由命名。

	<!-- 被 vm 实例所控制的区域 -->
    <div id="app">
      <router-link to="/user/1">User1</router-link>
      <router-link to="/user/2">User2</router-link>
      <router-link :to="{ name: 'user', params: {id: 3} }">User3</router-link>
      <router-link to="/register">Register</router-link>

      <!-- 路由占位符 -->
      <router-view></router-view>
    </div>

    <script>
      const User = {
        props: ['id', 'uname', 'age'],
        template: '<h1>User 组件 -- 用户id为: {{id}} -- 姓名为:{{uname}} -- 年龄为:{{age}}</h1>'
      }

      const Register = {
        template: '<h1>Register 组件</h1>'
      }

      // 创建路由实例对象
      const router = new VueRouter({
        // 所有的路由规则
        routes: [
          { path: '/', redirect: '/user' },
          {
            // 命名路由
            name: 'user',
            path: '/user/:id',
            component: User,
            props: route => ({ uname: 'zs', age: 20, id: route.params.id })
          },
          { path: '/register', component: Register }
        ]
      })

      // 创建 vm 实例对象
      const vm = new Vue({
        // 指定控制的区域
        el: '#app',
        data: {},
        // 挂载路由实例对象
        // router: router
        router
      })
    </script>

6.编程式导航

导航的方式有两种:
1.声明式导航:通过点击链接的方式实现的导航
2.编程式导航:调用js的api方法实现导航

Vue-Router中常见的导航方式:
this.$router.push("hash地址");
this.$router.push("/login");
this.$router.push({ name:'user' , params: {id:123} });
this.$router.push({ path:"/login" });
this.$router.push({ path:"/login",query:{username:"jack"} });

this.$router.go( n );//n为数字,参考history.go
this.$router.go( -1 );

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值