start

HTML

Use the router-link component to navigate

/ / note: // 2, <router-link> is rendered as a '<a>' tag by default // navigation <router-link to="/foo">Go to foo </router-link> <! <router-view></router-view>Copy the code

javascript

Programming using a modularity mechanism (by injecting the router, we can access the router through this.router, access the router through this.router, and access the current route through this.route from any component)

// import Vue and VueRouter, Vue. Use (VueRouter) import Vue from 'Vue' import Router from 'vue-router' vuue. Use (Router) // 2 Const routes = [{path: '/Home', component: Home},] // create router instance, export default new router ({routes // {routes}) // create and mount the root instance (router.js) Const app = new Vue({router}).$mount('#app')Copy the code

Dynamic Route Matching

Common requirements: For example, we have a User component that is used to render for all users with different ids; For example, the details page jumps

Import User from '@/views/modules/ user.vue 'export default new Router({routes: [// dynamic path parameters start with a colon {path: '/user/:id', component: User } ] })Copy the code

The parameter id is set to this.$route.params and can be used within each component

Console. log(this.$route.params.id);Copy the code

Embedded routines by

To render components in nested exits, use the children configuration in the parameters of the VueRouter

export default new Router({ routes: [ { path: '/user/:id', component: User, children: [{// If /user/:id/profile matches successfully, // UserProfile will be rendered in user's <router-view> path: 'profile', Component: UserProfile}, {// When /user/:id/posts match successfully // UserPosts will be rendered in user <router-view> path: 'posts', component: UserPosts } ] } ] })Copy the code

Programmatic navigation

1. Navigate to a different URL using this.$router.push().

Note: This method adds a new record to the history stack, so when the user clicks the browser back button, it returns to the previous URL.

Router.push ('home') // Object router.push({path: 'home'}) // Named route Router.push ({name: 'user', params: {userId: '123'}}) Plan =private router.push({path: 'register', query: {plan: 'private'}}) !!!!!!!! const userId = '123' router.push({ name: 'user', params: { userId }}) // -> /user/123 router.push({ path: ` ` / user / ${username}}) / / - > / user / 123 / / params does not effect the router here. Push ({path: '/ user' params: {username}}) / / - > / userCopy the code

Note: If the destination is the same as the current route and only the parameters change (e.g. from one user profile to another /users/1 -> /users/2), you need to use beforeRouteUpdate to respond to the change (e.g. fetching user information).

Router.replace is similar to router.push, except that it does not add a new record to history. Instead, it replaces the current history record with its method name.




Programmatic: this.$router.push()

Route component parameters are transmitted

Decoupled components and routes using props, providing three modes (Boolean, object, and function)

Simple validation of the three modes

User.vue

Name = {{name}} id = {{id}}</div> <div> query1 = {{query1}} query2 = {{query2}}</div> </div> </template> <script> export default { props: ['id', 'name', 'query1', 'query2'], } </script>Copy the code

router.js

import User from '@/views/modules/User.vue' export default new Router({ routes: [ { path: '/user/:id/:name', // the name and id parameters passed here must also be called in the component. Component: user, // First writing: Boolean mode // props: /* props: {id: 'No0101', name: 'laven',}, */ / (route) => ({ id: route.params.id, name: route.params.name, query1: route.query.query1, query2: route.query.query2 }) }, ] })Copy the code