Vue前端路由hash与history差异深入了解

Vue前端路由hash与history差异深入了解

前言

随着前端技术的发展,单页面应用(SPA)越来越多地出现在我们的生活中,而Vue作为目前较为流行的前端框架,其前端路由功能也越来越重要。本文将详细讲解Vue前端路由中hash与history两种模式的差异,以及它们的使用注意事项。

hash模式

在vue-router中,默认使用的是hash模式。hash模式会将URL中#后的字符作为路由地址使用。

例如,当前URI为https://www.example.com,且应用的路由地址为/home时,hash模式下的URL为https://www.example.com/#/home

在hash模式下,通过修改location.hash的值,我们可以实现前端路由的跳转,例如:

// 跳转到/home页面
location.hash = '#/home';

值得注意的是,当我们使用hash模式路由时,浏览器不会向服务器发送请求。因此,一个明显的优势是我们不需要服务器支持URL重定向或django等框架的的特定设置。但是,URL带有#号,看起来并不友好。

history模式

history模式中,vue-router会使用浏览器的history API来实现前端路由。这种模式下的URL更友好,不存在hash的问题。例如:我们访问URI为https://www.example.com,且应用的路由地址为/home时,history模式下的URL为https://www.example.com/home

在history模式下,我们可以使用router.push()来实现路由跳转:

// 跳转到/home页面
router.push('/home');

在history模式下,我们需要在服务器端配置,以保证刷新浏览器的时候不会404。在Nginx中,我们可以添加以下配置实现:

location / {
    try_files $uri $uri/ /index.html;
}

这个是由于浏览器在刷新的时候,会根据URL路径从服务器请求资源,因为history模式下的URL跟真实的URI是一样的,不做任何服务器端配置会直接返回404错误。而使用上面的Nginx配置,服务器会先尝试加载URL中指定的文件,如果没有找到,则返回index.html,这样就保证了单页面应用的正常运行。

类似的,如果你使用Apache作为服务器,在.htaccess文件中可以加入以下配置实现:

<IfModule mod_rewrite.c>
    RewriteEngine On
    RewriteBase /
    RewriteRule ^index\.html$ - [L]
    RewriteCond %{REQUEST_FILENAME} !-f
    RewriteCond %{REQUEST_FILENAME} !-d
    RewriteRule . /index.html [L]
</IfModule>

综合比较

hash模式 history模式
URL友好度 较差 较好
是否向服务器发送请求
服务器端配置 不需要 需要
兼容性 更好 较差

示例

示例1

在Vue项目中,我们可以通过以下代码来判断当前应用的路由模式:

if (window.history && window.history.pushState) {
  // 支持history模式
  router.mode = 'history';
} else {
  // 不支持history模式,则使用hash模式
  router.mode = 'hash';
}

示例2

在Nginx配置文件中添加上述Nginx配置,以支持history模式下的刷新。

server {
    listen 80;
    server_name example.com;

    root /path/to/your/root;

    index index.html;

    location / {
        try_files $uri $uri/ /index.html;
    }
}

当浏览器以history模式的URL访问网站时,Nginx服务器会尝试获取对应的路径,如果存在则返回文件;否则,返回index.html

本站文章如无特殊说明,均为本站原创,如若转载,请注明出处:Vue前端路由hash与history差异深入了解 - Python技术站

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

相关文章

  • javascript实现仿银行密码输入框效果的代码

    要实现仿银行密码输入框效果的代码,可以参考如下的攻略: 1. HTML代码 首先,在HTML中需要创建一个文本框,该文本框用于输入密码。为了保证输入的密码的安全性,我们需要将该文本框的type属性设置为password,例如: <input type="password" id="password" /> …

    JavaScript 2023年6月11日
    00
  • 微信小程序实现给嵌套template模板传递数据的方式总结

    下面我将为你详细讲解微信小程序实现给嵌套template模板传递数据的方式总结。 1. 使用WXS方式获取数据 我们可以使用WXS方式来获取数据,并在模板中使用。具体步骤如下: 在当前页面或组件的JS文件中定义WXS方法,例如: const getTemplateData = function(templateId) { // 在这里获取并返回数据 } mo…

    JavaScript 2023年6月10日
    00
  • Vue之定义全局工具类问题

    为了更好地解释“Vue之定义全局工具类问题”,我们先来了解一下Vue中全局对象和局部对象的概念。 在Vue中,我们可以通过Vue对象来访问全局对象,例如Vue.directive、Vue.filter等对象就属于全局对象。在Vue实例中,可以通过this.$xxx来访问内置局部对象及自定义局部对象,例如this.$router、this.$store等。 而…

    JavaScript 2023年6月10日
    00
  • js字符串引用的两种方式(必看)

    JS字符串引用的两种方式 在JavaScript中,字符串是一个常见的数据类型。在使用字符串的过程中,我们需要通过引用字符串来进行操作。在JavaScript中,有两种常见的字符串引用方式,分别是单引号和双引号。 单引号字符串引用 使用单引号引用的字符串,需要在字符串的开头和结尾都添加单引号。 let str1 = ‘这是一个使用单引号引用的字符串’; co…

    JavaScript 2023年5月28日
    00
  • js获得当前时区夏令时发生和终止的时间代码

    要获取当前时区夏令时发生和终止的时间,可以使用 JavaScript 的 Date 对象的方法。 获取夏令时开始和结束的时间 要获取夏令时的开始和结束时间,可以使用以下代码: // 获取当前时间的时区偏移量 var offset = new Date().getTimezoneOffset(); // 构建夏令时开始和结束的日期对象 var dstStart…

    JavaScript 2023年5月27日
    00
  • javascript阻止浏览器后退事件防止误操作清空表单

    下面我将详细讲解如何使用JavaScript阻止浏览器后退事件,以防止误操作清空表单。 什么是阻止浏览器后退事件? 在浏览器中,当我们按下”后退”按钮或点击浏览器的返回箭头时,浏览器会自动回退到上一个页面,这就是浏览器的后退事件。 但是,在某些情况下,我们不希望用户回退到上一个页面,比如在填写表单时,用户误操作点击了后退按钮,导致表单数据丢失。此时,我们可以…

    JavaScript 2023年6月11日
    00
  • JavaScript 删除或抽取字符串指定字符的方法(极为常用)

    对于JavaScript删除或抽取字符串指定字符的方法,我们可以使用以下三种方式实现: 方法一:使用replace() 使用replace方法可以将字符串中指定的字符替换为指定的字符(或者为空字符),从而达到删除或抽取的效果。用法如下所示: str.replace(要替换的字符, 替换为的字符); 其中,要替换的字符可以是一个普通字符,也可以是一个正则表达式…

    JavaScript 2023年5月28日
    00
  • Javascript中Eval函数的使用

    当我们需要将某个字符串当做JavaScript代码来执行时,Eval函数就可以派上用场了。Eval函数的学习对于理解和书写高级JavaScript代码具有一定的帮助。 什么是 Eval 函数 Eval函数是JavaScript内置的一个全局函数,可以将指定的字符串解析为JavaScript代码并执行。通常我们会把一段需要执行的JavaScript代码以字符串…

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