Detailed explanation of the two modes of Router routing in Vue: hash and history

Detailed explanation of the two modes of Router routing in Vue: hash and history

hash mode (default)

Working principle: Monitor the hash value changes of the web page—> onhashchange event, get location.hash

Use a hash of the URL to simulate a full URL, so the page doesn't reload when the URL changes.

It will give the user the feeling that the web page has been redirected, but in fact it has not been redirected.

Mainly used in single page applications (SPA)

//Simulation principle//Monitor page hash value changes window.onhashchange = function(){
	// Get the hash value of the current url const _hash = location.hash
	// Display different content according to different hash values ​​switch(_hash) {
	     case '/#a':
	        document.querySelector('#app').innerHTML = '<h1>I am page 1 content</h1>'
	        break;
	     case '/#b':
	        document.querySelector('#app').innerHTML = '<h1>I am page 2 content</h1>'
	        break;
	     case '/#c':
	        document.querySelector('#app').innerHTML = '<h1>I am page 3 content</h1>'
	        break;
	} 
}

history mode

Working principle: Mainly use history.pushState() API to change the URL without refreshing the page.

There are actually five modes that can change the URL without refreshing the page.

history.pushState()

history.replaceState()

history.go()

history.back() --> Equivalent to history.go(-1)

history.forward() --> Equivalent to history.go(1)

Need backend configuration support. If you enter a URL that does not exist, the backend configuration needs to be used as a "backup configuration". Instead of returning a 404, it returns to the home page.

Enable history mode

const router = new VueRouter({
  mode: 'history',
  routes: [...]
})

The above is the detailed content of the two modes of Router routing in Vue, hash and history. For more information about the Router routing mode in Vue, please pay attention to other related articles on 123WORDPRESS.COM!

You may also be interested in:
  • Detailed explanation of Vue-router nested routing
  • vue.js Router nested routes
  • Detailed explanation of Vue routing router
  • Implementation of nested jump of vue routing view router-view
  • Detailed explanation of VueRouter routing
  • Detailed explanation of Vue router routing

<<:  A brief analysis of MySQL locks and transactions

>>:  Analysis of the Linux input subsystem framework principle

Recommend

Summary of HTML knowledge points for the front end (recommended)

1. HTML Overview htyper text markup language Hype...

How to use HTML form with multiple examples

Nine simple examples analyze the use of HTML form...

Detailed explanation of JavaScript program loop structure

Table of contents Select Structure Loop Structure...

Basic tutorial on using explain statement in MySQL

Table of contents 1. Overview 1. Explain statemen...

How to set up Spring Boot using Docker layered packaging

The Spring Boot project uses docker containers, j...

CocosCreator general framework design resource management

Table of contents Problems with resource manageme...

How to solve the problem of automatic package update in Debian system

I don't know when it started, but every time ...

Detailed explanation of Docker container network port configuration process

Exposing network ports In fact, there are two par...

Detailed explanation of MySQL data grouping

Create Group Grouping is established in the GROUP...

How to optimize a website to increase access speed update

Recently, the company has begun to evaluate all s...

In-depth explanation of MySQL common index and unique index

Scenario 1. Maintain a citizen system with a fiel...