详解vue-router基本使用

来源:https://m.jb51.net/article/111499.htm
 
本篇文章主要介绍了详解vue-router基本使用,详细的介绍了vue-router的概念和用法,有兴趣的能够了解一下。

路由,其实就是指向的意思,当我点击页面上的home  按钮时,页面中就要显示home的内容,若是点击页面上的about 按钮,页面中就要显示about 的内容。Home按钮  => home 内容, about按钮 => about 内容,也能够说是一种映射。 因此在页面显示中,有两个部分,一个是须要点击的部分,一个是点击以后,显示点击内容的部分。javascript

点击以后,怎么作到正确的对应,好比,我点击home 按钮,页面中怎么才能显示home的内容。这就要在js 文件中配置路由。html

路由中有三个基本的概念 route, routes, router。vue

1, route,它是一条路由,由这个英文单词也能够看出来,它是单数, Home按钮  => home内容, 这是一条route,  about按钮 => about 内容, 这是另外一条路由。html5

2, routes 是一组路由,把上面的每一条路由组合起来,造成一个数组。[{home 按钮 =>home内容 }, { about按钮 => about 内容}]java

3, router 是一个机制,至关于一个管理者,它来管理路由。由于routes 只是定义了一组路由,它放在哪里是静止的,当真正来了请求,怎么办? 就是当用户点击home 按钮的时候,怎么办?这时router 就起做用了,它到routes 中去查找,去找到对应的 home 内容,因此页面中就显示了   home 内容。vue-router

4,客户端中的路由,实际上就是dom 元素的显示和隐藏。当页面中显示home 内容的时候,about 中的内容所有隐藏,反之也是同样。客户端路由有两种实现方式:基于hash 和基于html5 history api.vue-cli

vue-router中的路由也是基于上面的内容来实现的api

在vue中实现路由仍是相对简单的。由于咱们页面中全部内容都是组件化的,咱们只要把路径和组件对应起来就能够了,而后在页面中把组件渲染出来。数组

1, 页面实现(html模版中)浏览器

在vue-router中, 咱们也能够看到它定义了两个标签<router-link> 和<router-view>。 <router-link> 就是定义页面中点击的部分,<router-view> 就是点击后,显示内容的部分。因此 <router-link> 还有一个很是重要的属性 to, 它定义 点击以后,要到哪一个路径下 , 如:<router-link  to="/home">Home</router-link>

2, js 中配置路由

首先要定义route,  一条路由的实现。它是一个对象,最基本的一条路由由两个部分组成: path: component.  path 指路径,component 指的是组件。如:{path:'/home', component: home}

咱们这里有两条路由,组成一个routes:

const routes = [
 { path: '/home', component: Home },
 { path: '/about', component: About }
]

  

最后建立router 对路由进行管理,它是由构造函数 new vueRouter() 建立,接受routes 参数。

const router = new VueRouter({
   routes // short for routes: routes
})

  

配置完成后,把router 实例注入到 vue 根实例中,就可使用路由

const app = new Vue({
 router
}).$mount('#app')

  

执行过程:当用户点击 router-link 标签时,会去寻找它的 to 属性, 它的 to 属性和 js 中配置的路径{ path: '/home', component: Home}  path 一一对应,从而找到了匹配的组件, 最后把组件渲染到 <router-view> 标签。全部的这些实现才是基于hash 实现的。

vue-cli 建立一个项目体验一下, 固然不要忘记安装vue-router

1, 在src 目录下新建两个组件,home.vue 和 about.vue

<template>
  <div>
    <h1>home</h1>
    <p>{{msg}}</p>
  </div>
</template>
<script>
  export default {
    data () {
      return {
        msg: "我是home 组件"
      }
    }
  }
</script>

  

<template>
  <div>
    <h1>about</h1>
    <p>{{aboutMsg}}</p>
  </div>
</template>
<script>
  export default {
    data () {
      return {
        aboutMsg: '我是about组件'
      }
    }
  }
</script>

  

2, 在 App.vue中 定义<router-link > 和 </router-view> 

<template>
 <div id="app">
  <img src="./assets/logo.png">
  <header>
  <!-- router-link 定义点击后导航到哪一个路径下 -->
   <router-link to="/home">Home</router-link>
   <router-link to="/about">About</router-link>
  </header>
  <!-- 对应的组件内容渲染到router-view中 -->
  <router-view></router-view>  
 </div>
</template>

<script>
export default {
 
}
</script>

  

3,  在 src目录下再新建一个router.js 定义router, 就是定义 路径到 组件的 映射。

import Vue from "vue";
import VueRouter from "vue-router";

// 引入组件
import home from "./home.vue";
import about from "./about.vue";

// 要告诉 vue 使用 vueRouter
Vue.use(VueRouter);

const routes = [
  {
    path:"/home",
    component: home
  },
  {
    path: "/about",
    component: about
  }
]

var router = new VueRouter({
  routes
})
export default router;

  

4, 把路由注入到根实例中,启动路由。这里其实还有一种方法,就像store 注入到根实例中,咱们能够在main.js中引入路由,注入到根实例中。

import Vue from 'vue'
import App from './App.vue'

// 引入路由
import router from "./router.js"
new Vue({
 el: '#app',
 router, // 注入到根实例中
 render: h => h(App)
})

  

5, 这时点击页面上的home 和about 能够看到组件来回切换。可是有一个问题,当首次进入页面的时候,页面中并无显示任何组件。咱们想让页面一加载进来就显示home页面,这须要重定向,所谓重定向,其实就是从新给它指定一个方向,好比当用户点击home 的时候,咱们让它指向about.

这用到了redirect 配置。刚进入页面的时候,它的路径是 '/', 因此从新定义到home

const routes = [
  {
    path:"/home",
    component: home
  },
  {
    path: "/about",
    component: about
  },
  // 重定向
  {
    path: '/', 
    redirect: '/home' 
  }
]

  

6, 当咱们打开浏览器的控制台,能够看到路由时组件的切换。

首先看到 router-link 标签渲染成了 a 标签,to 属性变成了a 标签的 href 属性,这时就明白了点击跳转的意思。router-view 标签渲染成了咱们定义的组件。能够对比一下app.vue 中的标签和控制台中的标签

 

 动态路由

官网给的例子是,不一样的用户(就是用户的id不一样),它都会导航到同一个user  组件中。这样咱们在配置路由的时候,就不能写死, 就是路由中的path属性,不能写死。如 path: “/home”,只有是home的时候,才能显示home 组件,执行的是严格匹配。导航到 user 组件,路径中确定有user,

id 不一样,那就给路径一个动态部分来匹配不一样的id. 动态部分 以 : 开头,那么路径就变成了 /user/:id, 这条路由就能够这么写: { path:"/user/:id", component: user }.

再定义一个user组件,页面中添加两个router-link 用于导航, router.js中添加路由配置。user组件随便写一个就行了。

app.vue 更改以下:

<template>
 <div id="app">
  <img src="./assets/logo.png">
  <header>
   <router-link to="/home">Home</router-link>
   <router-link to="/about">About</router-link>
   <!-- 增长两个到user组件的导航,能够看到这里使用了不一样的to属性 -->
   <router-link to="/user/123">User123</router-link>
   <router-link to="/user/456">User456</router-link>
  </header>
  <router-view></router-view>  
 </div>
</template>

  

router.js 更改以下:

const routes = [
  {
    path:"/home",
    component: home
  },
  {
    path: "/about",
    component: about
  },
  /*新增user路径,配置了动态的id*/
  {
    path: "/user/:id",
    component: user
  },
  {
    path: '/', 
    redirect: '/home' 
  }
]

  

在动态路由中,若是咱们想知道路由是从哪里过来的,就是获取到动态部分怎么办? 其实,当整个vue-router 注入到根实例后,在组件的内部,咱们是能够经过this.$route.params 来得到这个动态部分的。它是一个对象,属性名,就是路径中定义的动态部分 id, 属性值就是router-link中to 属性中的动态部分,如123。 在组件中,若是想要获取到state 中的状态,咱们能够用computed 属性,在这里也是同样,在组件中,定义一个computed 属性dynamicSegment, user 组件修改以下:

<template>
  <div>
    <h1>User</h1>
    <div>我是user组件, 动态部分是{{dynamicSegment}}</div>
  </div>
</template>
<script>
  export default {
    computed: {
      dynamicSegment () {
        return this.$route.params.id
      }
    }
  }
</script>
相关文章
相关标签/搜索