1, an overview of the

Vue-router and vue.js are deeply integrated and suitable for single-page applications. The traditional route uses some hyperlinks to realize page switching and skipping. Vue-router, on the other hand, switches between components in a single page application. The essence is to establish and manage the mapping between urls and their corresponding components.

2, use,

2.1. Install vueRouter4:

npm install vue-router@4
Copy the code

2.2. Configure the router.js file of the routing instance

/ / 1, route map, createWebHashHistory is to create the historical pattern of routing import {createRouter createWebHashHistory, createWebHistory} from 'vue - the router' Import Home from '.. /components/Home.vue' import Mine from '.. Const routes=[{path:'/home',component: home}, {path:'/home',component: home}, {path: '/ mime, component: mime}] / / 4, create routing const router = createRouter ({history: createWebHashHistory (), / / set the routing orientation mode routes}) Export the route export default routerCopy the code

Import router.js from main.js and mount it to Vue instance

Import {createApp} from 'vue' import App from './ app. vue' // Import router from './router' const App = Use (router) app.mount('# App ')Copy the code

2.4. Routing is used in VUE components

<template> <div> <! Navigation -- -- -- > < div id = "nav" > < the router - link to = "/ home" > home page < / router - the link > < the router - link to = "/ mime" > I < / router - the link > < / div > <! -- Router --> <router-view></router-view> </div> </template> <script > export default {setup (context){return {} } } </script> <style> </style>Copy the code
  • Router-link: Creates a tag to define the route navigation link (the user can click to jump to the route), uses the to attribute to specify the destination address, and renders it as a tag with the correct link by default.
  • Router-view: Renders the view component that your route matches within the tag.

2.5. Use route redirection

The direct command is used for route redirection.

Const routes=[// route {path:'/',redirect:'/home'}, {path:'/home', Component: home}, {path:'/home',component: home}, {path:'/mine',component:Mine} ]Copy the code

2.6 Router-link common attribute active-class

Active-class: Add an active style.

<div id="nav"> <router-link to="/home" active-class="current"> Active-class ="current"> my </router-link> </div>Copy the code

In addition, router-Link has a default selected style class

.router-link-active {
  font-size:18px;
  color: golden;
  font-weight: bolder
}
Copy the code

2.7 Router-link’s common attribute Replace

Replace replaces a stack without caching.

<div id="nav"> <router-link to="/home" replace> </router-link> <router-link to="/mine" replace> my </router-link> </div>Copy the code

3. Two modes of VUe-Router

Vue-router provides two ways to implement front-end routing :Hash mode and History mode. The mode parameter can be used to determine which mode to use.

3.1. Hash Mode

Vue-router uses Hash mode by default. It uses the Hash of url to simulate a complete URL. If the URL changes, the browser will not reload. Hash(that is, #) is the anchor point of the URL and represents a location in the web page. Simply change the following part of the # and the browser will scroll through the location without reloading the page. It’s just a guide for the browser, not for the server at all! It is not included in the HTTP request and therefore does not reload the page. And when the hash changes, the URL is logged by the browser, so you can use the browser’s back.

To summarize :Hash mode is a way to implement browser-rendered components by changing the value after #.

3.2. History Mode

If you don’t like hash #, you can use history mode, which takes advantage of HTML5 History’s new pushState() and replaceState() methods. In addition to the previous back, Forward, and Go methods, the two new methods can be used to add and replace the browser History, using the History mode to change the URL, but it does not immediately send requests to the back end. Note: Although History mode can discard ugly # and move forward or backward normally, refreshing F5 will result in a 404! “However, to play this mode well, you need to support the background configuration,” the official document states. Because our application is a single client application, if the background is not properly configured, when the user accesses it directly, it will return 404, so you need to add a candidate resource on the server that covers all cases; If the URL does not match any static resources, the same index.html page should be returned.

To summarize :History mode is a way to modify the browser's History through pushState() without asking the back end to render it. However, it is recommended to use the history mode for the actual project.

Example:

Const router = createRouter({history: createWebHashHistory(), // Default hash route})Copy the code

4. Dynamic route matching

When we need to match a pattern to all routes, all map to the same component. For example, we have a User component that will be used to render for all users with different ids. At this point we can configure dynamic routing implementation. Dynamic route matching is essentially passing parameters through urls

4.1 introduction to attributes of routing objects

Here are some common route object attributes for ease of understanding. You can use $route(not $router!) within a component. Make an interview.

$route.path Type: string Indicates the path of the current route. It is always resolved to an absolute path, such as “/foo/bar”.

$route.params Type: Object A key/value Object that contains dynamic fragments and fully matched fragments, and is empty if there are no routing parameters.

$route.query type: Object A key/value Object representing a URL query parameter. For example, for path /foo? $route.query.user == 1; $route.query.user == 1;

$route.name Specifies the name of the current route, if any. It is recommended that each routing object be named for later programmatic navigation. But remember that the name must be unique!

Hash type: string Hash value of the current route (with #). If there is no hash value, it is an empty string.

$route.fullPath: string Parsed URL, containing query parameters and the full hash path.

4.2 Configuration using Params:

Routes :[{// dynamic path parameter starting with a colon path:'/user/:id', Component: user}]Copy the code

In this case, params is used for configuration. Things like /user/foo and /user/bar will map to the same route.

  • A path parameter is marked with a ‘:’ colon.
  • When a route is matched, the parameter is set to$route.paramsCan be used within each component. For example/user/foo in$route.params.idFor the foo.

Here is an example of an official table

model Matching path $route.params
/user/:username /user/evan { username: 'evan' }
/user/:username/post/:post_id /user/evan/post/123 { username: 'evan', post_id: 123 }

Here’s another example with a slight twist to help you understand:

routes:[
	{path:'/user/:shot/foo/:id', component:shotCat}
]
Copy the code
<p> <router-link to="/user/shot/foo">/user/shot/foo</router-link> <! <router-link to="/user/shot/cat/foo">/user/shot/cat/foo</router-link> <! --> <router-link to="/user/foo/foo/foo">/user/foo/foo/foo /foo</router-link> <! $route.params.shot = foo; $route. Params. The cat is foo; --> <router-link to="/user/shot/foo/cat">/user/shot/foo/cat</router-link><! $route.params.shot = shot; $route. Params. Cat cat; --> </p> <router-view></router-view>Copy the code

tips:

  • Sometimes, a path can match multiple routes. In this case, the matching priorities are in the order defined by the routes. Whoever defines it first has the highest priority.

  • Because the routing parameters are reusable to the component instance. For example, /user/foo and /user/bar reuse the user component when using routing parameters. The component’s lifecycle hook is no longer called.

4.3. Configure parameter transmission using query

In the project we can pass the parameter through params mentioned above. You can also use query to pass parameters. For example:

foo
Vue-route The following id=foo is encapsulated in route.query. At this point, in the component route.query. At this point, in the component route.query. In this case, the value of route.query.id in the component is ‘foo’. In addition to the router-link to attribute, query can also be passed as a parameter through the programmatic navigation described later.

Programmatic navigation

Programmatic navigation is the same as

because it accesses routing instances through the router inside the VUE component and uses router-push to navigate to different urls for route mapping. Of course, if you have configured the corresponding routing object in routes.

When do you usually use programmatic navigation? If you want to do something else, such as permission validation, before the route jumps. If you use

, you can jump directly to the router. Now you can use programmatic navigation!

5.1 Writing method of programmatic navigation

Programmatic navigation typically uses the router.push method, which can take a string path or an object describing an address. Such as:

<script> import { useRouter } from "vue-router"; export default { setup() { const router = useRouter(); // const strHome = ()=>{router.push("home")}; / / object is const objHome = () = > {router. Push ({path: "home"})}; // Named route const nameUser = ()=>{router.push({name: "user", params: {userId: 2333}})}; // With query parameters, change to /register? plan=private const queryRegister = ()=>{router.push({ path: "register", query: { plan: "private" } })}; return { strHome, objHome, nameUser, queryRegister }; }}; </script>Copy the code

Note: Path and Params cannot work at the same time! Otherwise params will be ignored. So when params is passed with object notation, either path followed by a colon: or, as in the example above, ‘named route’, name and params are passed. Query, however, is not affected and can be passed with or without a path.

5.2. Router.replace method

Router. replace is similar to router.push. Push adds a new record to history, while replace simply replaces the current browser history!

What are the immediate consequences? Here’s an example:

  • Using the push method, page 1 goes to page 2, and you go back to page 1 using the browser.
  • With the replace method, page 1 is replaced with page 2, and you use the browser’s back, and you can’t go back to page 1, you can only go back to page 0, the page before page 1.

So when do you use replace? This is common when you don’t want the user to go back to the previous page, and then you don’t want the user to go back to the login page to authenticate again.

6. Nested routines are composed of single component and multiple views

  • Nested pattern: the parent route is nested with child routes, and /user is nested with two child routes, followed by /user/foo and /uer/bar. It is represented by a graph:

  • Single component multiple views: Is a component that has multiple views to display. It contains more than one<router-view/>

6.1. Nested routines are defined by

Before we start, it’s important to understand that a
corresponds to a component, so there are two key points to implement nested routines:

  • Define child routes in routing objects (nested child routes)
  • In the component<router-view/>The use of.

6.2. Define child routes in routing objects

Const routes = [{path: '/user', component: user, name: 'user', const routes = [{path: '/user', component: user, name: 'user', '', component: UserDefault, name: 'default', //children:[{}] // If there is no other match under /user, the user <router-view> will display nothing, if you want it to display something. 'foo', component: UserFoo, name: 'foo'}, // path is the same as '/user/foo', and the child route inherits the parent route's path. However, it cannot be written as path:'/foo'. Nested paths starting with/are treated as root paths, meaning that foo becomes the root path instead of user. 'bar', component: UserBar, name: 'bar' } ] } ]Copy the code

6.3. Inside components<router-view/>The use of.

<template> <div id="nav"> <p> <router-link to="/user">/user</router-link> <router-link to="/user/foo">/user/foo</router-link> <router-link to="/user/bar">/user/bar</router-link> </p> <router-view></router-view> <! -- Here is the User component; </div> </template>Copy the code
<template> <div class="user"> <h2>User</h2> <router-view></router-view> </div> </template> </div> </template>Copy the code
<template> here is the UserDefault page </template>Copy the code
<template> here is the UserFoo page </template>Copy the code
<template> here is the UserBar page </template>Copy the code

7. Lazy route loading

Components are loaded at the time of routing access, rather than at the beginning, which is more efficient.

Route index file:

// Const Home=()=>import('./.. /components/Home.vue') const Mine=()=>import('./.. /components/Mine.vue') const News=()=>import('./.. /components/News.vue')Copy the code

Case study:

/ / 1, route map, createWebHashHistory is to create the historical pattern of routing import {createRouter createWebHashHistory, createWebHistory} from 'vue - the router' // import Home from './.. /components/Home.vue' // import Mine from './.. /components/Mine.vue' // import News from './.. /components/ news.vue '// RSVP const Home=()=>import('./.. /components/Home.vue') const Mine=()=>import('./.. /components/Mine.vue') const News=()=>import('./.. // news.vue ') const routes=[{path:'/',redirect:'/home'}, {path:'/home',component: home}, {path:'/mine', Component: mine}, // Dynamic route, dynamic binding ID, use colon: {path: '/ news / : id, component: news}] / / 4, create routing const router = createRouter ({history: createWebHashHistory (), / / set the routing orientation mode // Export route export default routerCopy the code

8. Navigation Guard

8.1 Classification of navigation guards

Global guard: Asynchronously executed, with each route jump executed sequentially.

  • Router. BeforeEach Global front guard
  • Router.aftereach ((to, from) => {}); router.aftereach ((to, from) => {});

Each guard method takes three arguments:

  • To: Route: the target to be entered

  • From: Route: Indicates the Route object that the current navigation is leaving

  • Next: Function: Be sure to call this method to resolve the hook. The execution depends on the call parameters of the next method.

    • next(): Goes to the next hook in the pipe. If all hooks are executed, the state of the navigation isconfirmedConfirmed.
    • next(false): interrupts current navigation. If the browser URL changes (either manually by the user or by the browser back button), the URL is reset tofromIndicates the IP address of the route.
    • next('/')ornext({ path: '/' }): Jumps to a different address. The current navigation is interrupted and a new navigation is performed.
Router.beforeeach ((to, from, next) => {... next(); }); //2, you can also set the router inside the component. BeforeEach ((to, from, next) => {... next(); }); Router. BeforeEach ((to, from,) Next) => {// First of all, to and from are a routing object, so the attributes of the routing object are available (see the official routing object API documentation). Matched [0].next (); // Do not omit next!! // Next (false) interrupts current navigation //next('/path path ') or object next({path:'/path path '}) jumps to path routing address //next({path:'/shotcat',name:'shotCat',replace:true,query:{logoin:true}... } router-link to prop and router.push //next(error) (2.4.0+)}).catch(()=>{//next(error) (2.4.0+)}).catch(()=>{ Next ({path: '/error', replace: true, query: {back: Router.onerror () router.onError() router.onerror (callback => {console.log(' Error! ', callback); });Copy the code

9. Route meta information

9.1. What is routing meta information

Route configuration meta object information:

const routes = [
  {
    path: '/foo',
    component: Foo,
    children: [
      {
        path: 'bar',
        component: Bar,
        // a meta field
        meta: { requiresAuth: true }
      }
    ]
  }]
Copy the code

Add a custom meta object to the route and set a requiresAuth state to True.

9.2 what is it used for

The answer comes from another official chestnut below.

router.beforeEach((to, from, Next) => {if (to.matched. Some (record => record.meta. RequiresAuth)) {// Array some method, if meta. In this case, you need to check whether the user has logged in to the route. If (! Auth.loggedin ()) {next({path: '/login', query: {redirect: To.fullpath} // This little detail of the official example is very nice. The route path to jump to is saved by query. After login, you can get the path directly and jump to the route to go to before login. // Be sure to call next()}})Copy the code

We can determine whether login authentication is required based on the status set in the meta. If requiresAuth in the meta is true, you need to check whether you are logged in and jump to the login page if you are not. If you have logged in, continue to jump.

Path, Params, and Query can store information as status markers for login authentication. Indeed, they can achieve the same effect. If you have a small number of individual validations, using them is not a problem. But what if there are multiple routes that require login authentication? Path, Params, and Query explicitly store information in urls. And multiple paths add the same state information to the URL. This makes urls less simple and less elegant. So to convey information gracefully and implicitly, use meta objects!

10 and keep alive

Keep-alive is a built-in component of Vue. It is used to cache components in memory to prevent repeated DOM rendering, which consumes memory acquisition speed. A common use is to cache components or routes.

10.1, use,

A created-> Mounted life cycle is executed when a keepalive route or component is configured. A created-> Mounted life cycle is executed when a keepalive route or component is configured for a second time.

10.1.1 router Configuration cache

1) Step 1: Configure app.vue

<template> <! -- vue3.0 configuration --> <router-view V-slot ="{Component}"> <keep-alive> < Component :is="Component" v-if="$route.meta.keepAlive"/> </keep-alive> <component :is="Component" v-if="! $route.meta.keepAlive"/> </router-view> </template>Copy the code

Here component is the special component in the VUE, :is is used to bind the specified component, and here is the page binding corresponding to the route.

2) Step 2: Add meta attributes

Add meta attribute to the corresponding route to set whether the page should use cache, as follows:

{path: "/keepAliveTest", name: "keepAliveTest", meta: {keepAlive: true // set whether the page needs caching}, Component: () => import("@/views/keepAliveTest/index.vue") }Copy the code

Simple page caching can be implemented, but complex processing is required in some scenarios. For example, some page information does not need to be read from the cache and is processed each time it is entered. In this case, the Activated life cycle can be used to solve the partial page refresh problem.

3) Partially refresh the page

The lifecycle of a vUE is created-> Mounted -> Activated. The lifecycle of a vUE is created-> Mounted -> Activated. Created -> Mounted Indicates that the created-> Mounted value is executed only when a page is displayed for the first time. The Value of Activated is executed every time a page is displayed. This is a keepAlive life cycle.

Activated () {/ / page every time into the phone dynamic authentication code set to empty this. $refs. MobPwdCode. InputValue = ' '; },Copy the code

4) Dynamically set the keepAlive attribute of the route

Sometimes when we run out of keepalive cache and want to make the page no longer cached, or set the next page to keepalive, we can change the keepalive value of the meta to remove the page cache. Use beforeRouteEnter, beforeRouteUpdate, and beforeRouteLeave as follows:

BeforeRouteLeave (to, from, next) {// Set the meta to. Meta. KeepAlive = false for the next route; next(); }Copy the code

Reference: juejin. Cn/post / 684490…