vue-router的两种模式的区别

Vue Router 是一个官方的 Vue.js 路由管理器,它可以将组件与标识符映射为路由,然后将其传递给 Vue.js 实例进行渲染,在 Vue Router 中主要有两种路由模式:hash 模式和 history 模式。

hash 模式

hash 模式就是将路由信息放在 url 中的 hash (#)中,这种模式下的 url 格式为:

http://localhost:8080/#/home

在 Vue Router 中使用 hash 模式的代码如下:

const router = new VueRouter({
    mode: 'hash',
    routes: [
      {
        path: '/home',
        name: 'home',
        component: Home
      }
    ]
})

使用 hash 模式时,路由的变化不会导致浏览器向服务器发送请求,因为 hash 符号后面的内容是由浏览器自行解析的。并且 hash 模式下还可以根据 hashchange 事件进行路由的监听和切换。

history 模式

history 模式是使用 HTML5 的 history API 来实现 URI 与页面内容的映射关系,使用这种方式时,url 格式为:

http://localhost:8080/home

在 Vue Router 中使用 history 模式的代码如下:

const router = new VueRouter({
    mode: 'history',
    routes: [
      {
        path: '/home',
        name: 'home',
        component: Home
      }
    ]
})

相较于 hash 模式,history 模式更加简洁美观,但是要在服务器中进行相应的配置,否则在正常访问中会出现 404 错误,同时支持 history 模式的浏览器也有限。

示例:

在 hash 模式下,当我们从 /home 跳转到 /about 时,url 格式为:http://localhost:8080/#/about;而在 history 模式下,url 格式为:http://localhost:8080/about

// hash 模式下的代码示例
const router = new VueRouter({
    mode: 'hash',
    routes: [
      {
        path: '/home',
        name: 'home',
        component: Home
      },
      {
        path: '/about',
        name: 'about',
        component: About
      }
    ]
})

// history 模式下的代码示例
const router = new VueRouter({
    mode: 'history',
    routes: [
      {
        path: '/home',
        name: 'home',
        component: Home
      },
      {
        path: '/about',
        name: 'about',
        component: About
      }
    ]
})

总而言之,Vue Router 中的两种路由模式各有优缺点,我们可以根据具体业务场景来选择。

本站文章如无特殊说明,均为本站原创,如若转载,请注明出处:vue-router的两种模式的区别 - Python技术站

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

相关文章

  • js实现iGoogleDivDrag模块拖动层拖动特效的方法

    JS实现iGoogleDivDrag模块拖动层拖动特效是一项基于鼠标拖动功能的JavaScript特效。下面是实现该特效的攻略: 1. 添加HTML结构 首先,在HTML中添加需要拖拽的div元素,同时为目标div元素指定ID属性,例如: <div id="dragElement">需要拖拽的内容区域</div> …

    JavaScript 2023年6月11日
    00
  • javascript中的 object 和 function小结

    让我来为你详细讲解”JavaScript中的Object和Function小结”。 JavaScript中的Object 在JavaScript中,对象是一种复合数据类型,可以把它看做是多个属性的集合。对象的属性可以是基本数据类型,如字符串、数字等,也可以是其他对象以及函数。通过点(.)或中括号([])语法,可以访问和修改对象的属性。 例如,我们可以创建一个…

    JavaScript 2023年5月27日
    00
  • js的回调函数详解

    JS的回调函数详解 在Javascript中,回调函数(callback function)指的是一个函数作为另一个函数的参数,然后在这个函数执行完后,再执行这个函数。回调函数经常用到异步编程中。 回调函数的定义 回调函数作为一种设计模式,是把一个函数作为参数传递给另一个函数,让这个函数在另一个函数完成后调用。 回调函数的作用 回调函数主要用于异步编程。当一…

    JavaScript 2023年5月27日
    00
  • Node.js 和 Python之间该选择哪个?

    当你需要选择一种服务器端开发语言时,Node.js 和 Python 都是不错的选择。它们都有广泛的应用和生态系统,但它们之间也存在一些区别。 1. Node.js vs Python:概述 Node.js Node.js 是一种使用 JavaScript 编写的服务器端运行环境。它采用事件驱动、非阻塞 I/O 模型,使得它非常适合构建高性能的 Web 应用…

    JavaScript 2023年5月28日
    00
  • js怎么终止程序return不行换jfslk

    JS中终止程序有多种方式,但是通过return语句来终止程序是比较常见和方便的方法。如果使用return无法终止程序,可能是由于函数嵌套、异步操作等原因,下面我们来详细讲解如何解决。 函数嵌套 当函数嵌套的时候,使用return只能终止当前函数的执行,而不能终止外层函数的执行。这时需要使用return语句和一个标识符来协同工作,让外层函数在适当的时候捕获这个…

    JavaScript 2023年5月27日
    00
  • 让div运动起来 js实现缓动效果

    让div运动起来并实现缓动效果是Web开发中常见的需求之一。JS可以实现动态控制DOM节点的属性值,通过操作CSS属性的变化来实现节点的平移、缩放、旋转等动画效果,同时还可以结合缓动算法,使得CSS属性的变化更加平滑、自然。以下是一些实现div缓动效果的攻略和示例: 1.缓动算法介绍 在实现缓动效果时,使用缓动算法可以让CSS属性的变化更加自然、平缓,提升动…

    JavaScript 2023年6月11日
    00
  • JavaScript实现求最大公共子串的方法

    JavaScript实现求最大公共子串的方法 简介 最大公共子串(Longest Common Substring)是指两个或多个字符串中都出现的最长子串。在文本编辑、DNA序列比对和音频处理等领域都有广泛应用。 在JavaScript中,可以使用动态规划(Dynamic Programming)的方法来实现求最大公共子串的功能。动态规划是一种逐步递进的算法…

    JavaScript 2023年5月28日
    00
  • 浅谈js多维数组和hash数组定义和使用

    针对“浅谈js多维数组和hash数组定义和使用”的话题,我来进行详细讲解。 多维数组 JavaScript中的多维数组,其实就是由多个一维数组组成的数组。我们可以使用一维数组来构建多维数组,比如: const multiArr = [ // 二维数组 [1, 2, 3], [4, 5, 6], [7, 8, 9] ]; const threeDArr = […

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