Detailed explanation of Vue router routing guard

Detailed explanation of Vue router routing guard

1. Global beforeEach

When the name stored in Local Storage is zhangsan, the message content will be displayed only when the message is clicked

1. Global beforeEach

Add a routing guard to the router beforeEach

grammar:

router.beforeEach((to, from, next)=>{})

Function: Call the function in beforeEach during initialization and before each route switch

parameter:

1.to: target route

2.from: the route before the jump

3.next: release

2. Implementation

2. Requirement 2

If there are many paths that need to be judged before jumping, you need to write a lot of judgment code, and the judgment structure will be very complicated.

At this time, you can put a meta tag in the route that needs to be judged.

The meta tag provides metadata about the HTML document (metadata refers to data used to describe data)

At this time, you can use the tag field in meta to make a judgment

3. Global post-guard afterEach

The usage of afterEach and beforeEach is basically the same.

The difference is that afterEach does not have the next parameter

1. Change the title to your own title

Assign each route its own title name

const router = new VueRouter({
  routes: [
    {
      name: 'home',
      path: '/home',
      component: Home,
      meta: {
        title: "Home"
      },
      children: [ 
        {
          name: "xiaoxi",
          path: 'message',
          component: Message,
          meta: {
            title: "News"
          },
          children: [
            {
              name: 'xiangqing',
              path: 'detail',
              component: Detail,
              meta: {
                isAuth: true,
                title: "Message Details"
              }
            }
          ]
        }
      ]
    },
    {
      path: '/about',
      component: About,
      meta: {
        title: "About"
      }
    }
  ]
})

Modify the title name in beforeEach

router.afterEach((to, from) => {
  document.title = to.meta.title || "Test"
})

4. Guarding within components

1. beforeRouteEnter

Called when entering this component through routing rules

2. beforeRouteLeave

Called when leaving the component through routing rules

Summarize

This article ends here. I hope it can be helpful to you. I also hope you can pay more attention to more content on 123WORDPRESS.COM!

You may also be interested in:
  • Specific use of routing guards in Vue
  • Vue2.0 implements navigation guard (route guard)
  • Detailed explanation of Vue's hook functions (route navigation guards, keep-alive, life cycle hooks)
  • Detailed explanation of Vue's routing guard and keep-alive life cycle

<<:  How to stop CSS animation midway and maintain the posture

>>:  A Guide to Optimizing High-Performance Websites

Recommend

Let's talk about the v-on parameter problem in Vue

Use of v-on:clock in Vue I'm currently learni...

Detailed explanation of the basic use of centos7 firewall in linux

1. Basic use of firewalld start up: systemctl sta...

JavaScript using Ckeditor + Ckfinder file upload case detailed explanation

Table of contents 1. Preparation 2. Decompression...

HTML basics - CSS style sheets, style attributes, format and layout details

1. position : fixed Locked position (relative to ...

Solve the problem of running jupyter notebook on the server

Table of contents The server runs jupyter noteboo...

Detailed steps for completely uninstalling MySQL 5.7

This article mainly summarizes various problems o...

Detailed explanation of linux crm deployment code

Linux basic configuration Compile and install pyt...

MySQL 8.0.18 installation and configuration method graphic tutorial (linux)

This article records the installation and configu...

MySQL 8.0.16 winx64 installation and configuration method graphic tutorial

I just started learning about databases recently....

Native JavaScript to achieve skinning

The specific code for implementing skinning with ...

Vue3 navigation bar component encapsulation implementation method

Encapsulate a navigation bar component in Vue3, a...

JavaScript canvas to achieve meteor effects

This article shares the specific code for JavaScr...

How to quickly modify the table structure of MySQL table

Quickly modify the table structure of a MySQL tab...

Several situations where div is covered by iframe and their solutions

Similar structures: Copy code The code is as foll...