Vue Router路由hash模式与history模式详细介绍

Vue Router路由hash模式与history模式详细介绍

在Vue.js中,Vue Router是一个常用的路由管理器。Vue Router可以实现单页应用(SPA)的路由功能。在Vue Router中,有两种路由模式:hash模式和history模式。在本文中,我们将详细介绍这两种模式的区别和使用方法。

hash模式

hash模式是Vue Router的默认模式,在URL中使用“#”作为路由路径的锚点标记,不会触发页面的刷新,也不会向服务器发送请求。通过监听URL的变化,从而实现页面的路由切换。在Vue Router中,我们可以通过配置路由的mode参数来设置使用hash模式。

配置方法

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

示例

假设我们有两个路由,一个是首页(/),一个是关于我们(/about)。

// main.js
import Vue from 'vue'
import App from './App.vue'
import VueRouter from 'vue-router'
import Home from './components/Home.vue'
import About from './components/About.vue'

Vue.config.productionTip = false

Vue.use(VueRouter)

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

const router = new VueRouter({
  mode: 'hash',
  routes
})

new Vue({
  render: h => h(App),
  router
}).$mount('#app')

现在我们在App.vue中添加路由跳转的链接:

<template>
  <div>
    <router-link to="/">Home</router-link>
    <router-link to="/about">About</router-link>
    <router-view></router-view>
  </div>
</template>

在浏览器中输入localhost:8080/#/,可以看到页面显示为Home。点击About的链接,页面会跳转到localhost:8080/#/about,显示为About。

history模式

history模式使用浏览器的history API来实现路由功能,将页面路由信息保存在浏览器的history栈中,可以使用前进、后退按钮切换路由,也可以通过URL直接访问页面。

配置方法

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

需要注意的是,使用history模式需要服务器端支持,否则会出现404错误。如果要在开发环境中使用history模式,可以使用vue-cli提供的history模式的dev server。启动dev server的方法如下:

npm run dev -- --history

示例

假设我们有两个路由,一个是首页(/),一个是关于我们(/about)。

// main.js
import Vue from 'vue'
import App from './App.vue'
import VueRouter from 'vue-router'
import Home from './components/Home.vue'
import About from './components/About.vue'

Vue.config.productionTip = false

Vue.use(VueRouter)

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

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

new Vue({
  render: h => h(App),
  router
}).$mount('#app')

现在我们在App.vue中添加路由跳转的链接:

<template>
  <div>
    <router-link to="/">Home</router-link>
    <router-link to="/about">About</router-link>
    <router-view></router-view>
  </div>
</template>

在浏览器中输入localhost:8080,可以看到页面显示为Home。点击About的链接,页面会跳转到localhost:8080/about,显示为About。

以上是Vue Router路由hash模式与history模式的详细介绍。通过本文的学习,相信你已经掌握了这两种路由模式的使用方法。

本站文章如无特殊说明,均为本站原创,如若转载,请注明出处:Vue Router路由hash模式与history模式详细介绍 - Python技术站

(0)
上一篇 2023年6月11日
下一篇 2023年6月11日

相关文章

  • JavaScript正则表达式解析URL的技巧

    JavaScript正则表达式可以用于解析URL,可以通过正则表达式对URL进行匹配和处理,具体步骤如下: 使用正则表达式匹配URL中的协议、域名、路径、查询参数等各个部分; 将匹配结果包装成对象,方便后续的解析和处理; 通过对象的属性和方法对URL进行分析和操作。 下面分别对这三个步骤进行详细讲解。 1.使用正则表达式匹配URL的各个部分 正则表达式可以很…

    JavaScript 2023年6月10日
    00
  • JS中this的4种绑定规则详解

    下面是对于“JS中this的4种绑定规则详解”的完整攻略: 1. 默认绑定规则 默认绑定规则是指,在函数调用时,若函数调用时调用点没有指定调用的对象,this会绑定在全局对象上,即window(在浏览器环境下)。 示例代码如下: function foo() { console.log(this.a); } var a = 2; foo(); // 输出2 …

    JavaScript 2023年6月10日
    00
  • window.print()打印html网页的两种方法实现

    当我们在网页中呈现出需要打印的内容时,有时会需要将这些内容打印出来,在这时,我们可以使用 JavaScript 中的 window.print() 方法来实现网页打印功能。本篇文章将详细讲解“window.print()打印html网页的两种方法实现”的完整攻略。 一、使用 window.print() 方法实现网页打印功能 window.print() 方…

    JavaScript 2023年5月28日
    00
  • 详解TS对象扩展运算符和rest运算符

    详解TS对象扩展运算符和rest运算符 什么是对象扩展运算符和rest运算符 对象扩展运算符(也称为Spread运算符)和rest运算符(也称为剩余参数运算符)都是ES6新增的两种运算符。它们可以用于处理对象或数组中的元素,让代码更加简洁易读,常见于函数参数和数组/对象合并操作。 简单来说,对象扩展运算符可以将一个对象展开成多个对象,而rest运算符则可以将…

    JavaScript 2023年6月10日
    00
  • JavaScript中创建字典对象(dictionary)实例

    要在 JavaScript 中创建一个字典实例,可以使用 JavaScript 内置的对象类型之一:Object。Object 对象是一个通用的对象类型,它可以表示任何一个 JavaScript 对象,包括字典。 创建字典实例 创建一个空的字典实例,可以直接使用 Object 构造函数或对象字面量语法,例如: // 使用 Object 构造函数 const …

    JavaScript 2023年5月27日
    00
  • 在JavaScript中使用高阶函数的方法

    当我们谈论高级函数的时候,我们通常指的是那些将其它函数作为参数传递,或者返回一个函数的函数。这种函数可以让我们更轻松、更灵活地处理数据,因为它们能够在以前无法实现的层面上操作函数。 定义高阶函数 要获得最大的灵活性,我们可以编写 Function 类,以允许动态创建新函数: class FunctionFactory { constructor() { th…

    JavaScript 2023年5月27日
    00
  • Vue.js中数据绑定的语法教程

    首先我们来讲解Vue.js中数据绑定的语法教程。 简介 Vue.js是一款轻量级的、面向MVVM模式的JavaScript框架,广泛应用于Web前端开发中。 其中,数据绑定是Vue.js重要的功能之一,它允许对数据模型中的数据与视图进行双向绑定,进而实现动态数据的渲染和更新。 Vue.js的数据绑定语法主要有以下两种形式: 插值表达式(Interpolati…

    JavaScript 2023年6月11日
    00
  • javascript中函数作为参数调用的方法

    作为网站作者,我们需要详细讲解“JavaScript中函数作为参数调用的方法”的完整攻略。 什么是函数作为参数调用的方法? 在JavaScript中,函数可以作为参数传递给其他函数,在后者中被调用。这种函数作为参数调用的方法称为“函数回调”或“高阶函数”。 像其他数据类型一样,函数可以存储在变量中,并且可以作为参数传递给函数或从函数返回。通过这种方式,我们可…

    JavaScript 2023年5月28日
    00
合作推广
合作推广
分享本页
返回顶部