阿珊详解Vue路由的两种模式:hash模式与history模式

在这里插入图片描述

🤍 前端开发工程师、技术日更博主、已过CET6
🍨 阿珊和她的猫_CSDN博客专家、23年度博客之星前端领域TOP1
🕠 牛客高级专题作者、打造专栏《前端面试必备》 、《2024面试高频手撕题》
🍚 蓝桥云课签约作者、上架课程《Vue.js 和 Egg.js 开发企业级健康管理项目》、《带你从入门到实战全面掌握 uni-app》

文章目录

    • 摘要:
    • 引言:
    • 正文:
      • 1. 🔧 hash模式
      • 2. 🔧 history模式
      • 3. 🔧 两种模式的对比
    • 🌟 总结
    • 参考资料:

摘要:

🤔 Vue路由提供了两种模式:hash模式与history模式。本文将介绍这两种模式的特点与使用场景,帮助读者更好地掌握Vue路由的配置与应用。👩‍💻

引言:

🌈 Vue.js框架以其简洁的语法和声明式的数据绑定而受到开发者的喜爱。在单页面应用(SPA)中,路由管理是不可或缺的功能。Vue路由提供了两种模式:hash模式与history模式,以满足不同的开发需求。在这篇文章中,我将带你探究这两种模式的特点和应用,以期帮助你更好地运用Vue路由。🚀

正文:

1. 🔧 hash模式

在 web 开发中,hash 模式是一种页面跳转的方式,它不会改变浏览器的 URL,但页面会重新加载。

hash 模式的 URL 后面会跟一个 #,例如:http://example.com/#about

在 Vue 项目中,hash 模式通常用于前端路由。Vue 前端路由使用 hash 模式,是因为 hash 模式不需要后端支持,而且可以在不改变 URL 的同时实现页面跳转和数据更新。

Vue 项目使用 hash 模式的方法如下:

  1. 安装 vue-router:首先,需要安装 vue-router。在项目中引入 vue-router,可以通过 npm 或 yarn 安装:

    npm install vue-router --save
    

    yarn add vue-router
    
  2. 配置路由:在项目中创建一个名为 router.js 的文件,用于配置路由。首先,引入 vue 和 vue-router:

    import Vue from 'vue'
    import Router from 'vue-router'
    
    Vue.use(Router)
    

    然后,定义路由规则,并创建一个 Router 实例:

    export default new Router({
      mode: 'hash',
      routes: [
        {
          path: '/about',
          name: 'about',
          component: () => import('@/components/About.vue')
        },
        {
          path: '/',
          name: 'home',
          component: () => import('@/components/Home.vue')
        }
      ]
    })
    

    这里,mode 设置为 ‘hash’,表示使用 hash 模式。

  3. 在 main.js 中引入 router:在 main.js 文件中,引入刚刚创建的 router.js 文件:

    import Vue from 'vue'
    import App from './App.vue'
    import router from './router'
    
    new Vue({
      router,
      render: h => h(App)
    }).$mount('#app')
    
  4. 使用 router-view 组件:在需要跳转页面的地方,使用 router-view 组件。当点击 router-link 时,页面会根据配置的 hash 值进行跳转:

    <router-view></router-view>
    

总结来说,hash 模式是一种页面跳转的方式,不会改变浏览器的 URL,但页面会重新加载。在 Vue 项目中,hash 模式通常用于前端路由,通过 vue-router 实现。

2. 🔧 history模式

在 Web 开发中,history 模式是一种页面跳转的方式,它会在浏览器的 URL 栏中显示跳转后的页面地址,并且页面不会重新加载。history 模式的 URL 看起来和普通的 HTTP URL 一样,例如:http://example.com/about。

在 Vue 项目中,history 模式通常用于前端路由。Vue 前端路由支持 history 模式,使得页面跳转看起来更像传统的网站导航。

Vue 项目使用 history 模式的方法如下:

  1. 安装 vue-router:首先,需要安装 vue-router。在项目中引入 vue-router,可以通过 npm 或 yarn 安装:

    npm install vue-router --save
    

    yarn add vue-router
    
  2. 配置路由:在项目中创建一个名为 router.js 的文件,用于配置路由。首先,引入 vue 和 vue-router:

    import Vue from 'vue'
    import Router from 'vue-router'
    
    Vue.use(Router)
    

    然后,定义路由规则,并创建一个 Router 实例:

    export default new Router({
      mode: 'history',
      routes: [
        {
          path: '/about',
          name: 'about',
          component: () => import('@/components/About.vue')
        },
        {
          path: '/',
          name: 'home',
          component: () => import('@/components/Home.vue')
        }
      ]
    })
    

    这里,mode 设置为 ‘history’,表示使用 history 模式。

  3. 在 main.js 中引入 router:在 main.js 文件中,引入刚刚创建的 router.js 文件:

    import Vue from 'vue'
    import App from './App.vue'
    import router from './router'
    
    new Vue({
      router,
      render: h => h(App)
    }).$mount('#app')
    
  4. 使用 router-view 组件:在需要跳转页面的地方,使用 router-view 组件。当点击 router-link 时,页面会根据配置的 history 值进行跳转:

    <router-view></router-view>
    

总结来说,history 模式是一种页面跳转的方式,会在浏览器的 URL 栏中显示跳转后的页面地址,并且页面不会重新加载。在 Vue 项目中,history 模式通常用于前端路由,通过 vue-router 实现。

3. 🔧 两种模式的对比

  • URL表现:hash模式下URL包含#号,而history模式下URL更为简洁。
  • 性能:history模式在部分浏览器中可能会有性能问题,如重复的history.pushState调用。
  • 兼容性:hash模式兼容性更好,但history模式在现代浏览器中得到了广泛支持。

🌟 总结

在本篇文章中,我们详细解析了Vue路由的两种模式:hash模式与history模式。通过对比分析,我们应该对这两种模式有了更深入的了解。在实际开发中,根据项目需求和场景选择合适的模式,将使我们的Vue应用更加高效和优质。🚀

参考资料:

  1. Vue.js官方文档:路由
  2. Vue Router官方文档

🌟 感谢您的阅读!如果您有任何疑问或建议,欢迎在评论区留言。💬

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:/a/441388.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

Hotchips2018年-英伟达V100展示肌肉(未来芯片论坛及资料下载)

HOTCHIPS是什么&#xff1f; HOTCHIPS是一个关于计算机体系结构和电子设计的会议&#xff0c;主要探讨芯片设计、存储器、能源效率、机器学习和人工智能等方面的发展。该会议每年都会召开一次&#xff0c;吸引着来自世界各地的专业人士和研究人员。 在HOTCHIPS 2018年会上&a…

MySQL安装与卸载

安装 1). 双击官方下来的安装包文件 2). 根据安装提示进行安装(全部默认就可以) 安装MySQL的相关组件&#xff0c;这个过程可能需要耗时几分钟&#xff0c;耐心等待。 输入MySQL中root用户的密码,一定记得记住该密码 配置 安装好MySQL之后&#xff0c;还需要配置环境变量&am…

C++泛型实现搜索二叉树

文章目录 二叉搜索树查找插入删除实现应用性能分析 二叉搜索树 二叉搜索树&#xff08;BST&#xff0c;Binary Search Tree&#xff09;又称为二叉排序树&#xff0c;空树也算 二叉搜索树有如下性质 若左子树不为空&#xff0c;则左子树上所有节点值小于根节点若右子树不为空…

Tonka Finance,BTCFi 浪潮的发动机

在 2023 年年初&#xff0c;Ordinals 技术方案为比特币 Layer1 带来了一种全新的资产发行方式&#xff0c;此后一场以比特币生态为主战场的新一轮资金、注意力价值争夺战打响&#xff0c;并且越来越多的加密原教旨主义者、密码极客们加入这场战争中。我们看到&#xff0c;铭文市…

类和对象(1)(至尊详解版)

相信对于大家而言&#xff0c;对于类和对象都会是一头雾水吧&#xff01;什么是类&#xff1f;或者你有对象吗&#xff1f;那么本期的内容呢&#xff1f;就由我来为大家再次增加对于它们的理解&#xff0c;由于水平上的原因&#xff0c;可能会存在不当之处&#xff0c;敬请读者…

局域网管理工具

每个组织的业务运营方法都是独一无二的&#xff0c;其网络基础设施也是如此&#xff0c;由于随着超融合基础设施等新计算技术的发展&#xff0c;局域网变得越来越复杂&#xff0c;因此局域网管理也应该如此&#xff0c;组织需要量身定制的局域网管理解决方案&#xff0c;这些解…

【FPGA】DDR3学习笔记(一)丨SDRAM原理详解

本篇文章包含的内容 一、DDR3简介1.1 DDR3 SDRAM概述1.2 SDRAM的基础结构 二、 SDRAM操作时序2.1 SDRAM操作指令2.2 模式寄存器&#xff08;LOAD MODE REGISTER&#xff09;2.3 SDRAM操作时序示例2.3.1 SDRAM初始化时序2.3.2 突发读时序2.3.3 随机读时序2.3.4 突发写时序2.3.5 …

计算机这几个炮灰专业,选错毕业直接去搬砖

计算机五大专业&#xff0c;选错毕业后直接去搬砖。 在所有的计算机类专业中&#xff0c;计算机科学与技术这个专业既要学硬件&#xff0c;也要学软件&#xff0c;既要学理论&#xff0c;也要学技术。课程既有数理类&#xff0c;也有电器类&#xff0c;还有计算机类&#xff0…

MySQl基础入门⑥

上一章知识内容 1.数据类型的属性 2.MySql的约束 mysql的约束时指对数据表中数据的一种约束行为&#xff0c;约束主要完成对数据的检验&#xff0c;如果有互相依赖数据&#xff0c;保证该数据不被删除。它能够帮助数据库管理员更好地管理数据库&#xff0c;并且能够确保数据库…

LCR 175. 计算二叉树的深度

一、题目描述 LCR 175. 计算二叉树的深度 二、思路 递归求左右子树的高度 三、解题思路 把大规模的问题拆分成小规模的问题1、要求根节点的二叉树深度 2、转换子问题&#xff1a;求左子树为根节点的二叉树深度 3、转换子问题&#xff1a;成求右子树为根节点的二叉树深度 4、最…

华为北向网管NCE开发教程(2)REST接口开发

华为北向网管NCE开发教程&#xff08;1&#xff09;闭坑选接口协议 华为北向网管NCE开发教程&#xff08;2&#xff09;REST接口开发 华为北向网管NCE开发教程&#xff08;3&#xff09;CORBA协议开发 假设你现在要开始华为北向接口REST协议之前&#xff0c;需要准备如环境 1准…

OpenHarmony教程指南-自定义通知推送

介绍 本示例主要展示了通知过滤回调管理的功能&#xff0c;使用ohos.notificationManager 接口&#xff0c;进行通知监听回调&#xff0c;决定应用通知是否发送。 效果预览 使用说明 1.在使用本应用时&#xff0c;需安装自定义通知角标应用&#xff1b; 2.在主界面&#xff…

Golang基于Redis bitmap实现布隆过滤器(完结版)

Golang基于Redis bitmap实现布隆过滤器&#xff08;完结版&#xff09; 为了防止黑客恶意刷接口&#xff08;请求压根不存在的数据&#xff09;&#xff0c;目前通常有以下几种做法&#xff1a; 限制IP&#xff08;限流&#xff09;Redis缓存不存在的key布隆过滤器挡在Redis前 …

ChatGLM:CPU版本如何安装和部署使用

前段时间想自己部署一个ChatGLM来训练相关的物料当做chatgpt使用&#xff0c;但是奈何没有gpu机器&#xff0c;只能使用cpu服务器尝试使用看看效果 我部署的 Chinese-LangChain 这个项目&#xff0c;使用的是LLM&#xff08;ChatGLM&#xff09;embedding(GanymedeNil/text2vec…

【活动】2024年AI辅助研发:深度变革与无限潜力

作为一名前端程序员&#xff0c;深入探讨2024年AI在软件研发领域的应用趋势及其影响&#xff0c;我们可以看到一场引人注目的转型正在发生。AI辅助研发对于前端开发而言&#xff0c;不仅意味着效率的飞跃&#xff0c;更是在用户体验设计、代码编写、性能优化、项目管理等诸多方…

什么是Java内存模型

当问到 Java 内存模型的时候&#xff0c;一定要注意&#xff0c;Java 内存模型&#xff08;Java Memory Model&#xff0c;JMM&#xff09;它和 JVM 内存布局&#xff08;JVM 运行时数据区域&#xff09;是不一样的&#xff0c;它们是两个完全不同的概念。 1.为什么要有 Java …

Windows按文件类型指定默认应用程序方法,.py文件设置默认打开程序实例演示

有两种方法可以设置按文件类型指定默认应用。 一个是系统的设置&#xff0c;但是部分类型里面是没有的&#xff0c;这种就要通过注册表来添加。 如果没有的话&#xff0c;通过 winR 打开运行&#xff0c;然后输入 regedit 打开注册表&#xff0c;在 计算机\HKEY_CLASSES_ROO…

防御保护--IPSEC VPPN实验

实验拓扑图 实验背景&#xff1a;FW1和FW2是双机热备的状态。 实验要求&#xff1a;在FW5和FW3之间建立一条IPSEC通道&#xff0c;保证10.0.2.0/24网段可以正常访问到192.168.1.0/24 IPSEC VPPN实验配置&#xff08;由于是双机热备状态&#xff0c;所以FW1和FW2只需要配置FW1…

实景三维逛景区,VR智慧景区打造云上旅游新体验

哈尔滨旅游的爆火&#xff0c;让其他地方的文旅景区宣传也纷纷发力。VR智慧景区将传统的旅游体验从线下拓展至线上&#xff0c;为游客带来不一样的旅行体验&#xff0c;人们可以提前在手机上沉浸式体验景区的真实环境&#xff0c;避免实地游玩踩雷&#xff0c;也为人们节省了旅…

COMSOL中使用自定义函数

目录 函数的用法 &#xff08;1&#xff09;解析函数 &#xff08;2&#xff09;插值函数 &#xff08;3&#xff09;分段函数 &#xff08;4&#xff09;高斯脉冲 &#xff08;5&#xff09;斜坡函数 &#xff08;6&#xff09;阶跃函数 &#xff08;7&#xff09;矩形…