vue-router怎么实现history模式配置


本文小编为大家详细介绍“vue-router怎么实现history模式配置”,内容详细,步骤清晰,细节处理妥当,希望这篇“vue-router怎么实现history模式配置”文章能帮助大家解决疑惑,下面跟着小编的思路慢慢深入,一起来学习新知识吧。vue-router可以设置两种模式:hash和history如果使用hash模式,一般无需特殊配置;但如果要使用history模式,则前端和服务端要做一定的设置;使用history模式通常本地调试没有什么问题,但是一旦发布到测试或生产环境,则会出现页面白屏或者刷新页面白屏的现象,这种问题的出现是因为前端和服务端没有做相应的配置。2.1、前端配置首先要设置路由的mode和base两个值,如下:其次要设置vue.config.js里的publicPath,如下:如下图所示:至此,前端的配置工作就结束了。2.2、服务端配置(这里以nginx为例)官网其实有介绍,只是不太详细,这里直接上代码,如下:location /test-daily表示项目部署在了/test-daily目录下,这里要跟vue.config.js里的publicpath的值保持一致。之所以刷新页面白屏,其实是因为路由资源不存在,以本项目为例(home为首页路由的参数):https://test.xxx.yy/test-daily/home当访问上述路由时,其实根本就不存在相应的资源,当然会404了,为了避免这种情况的发生,可以让所有的路由都指向index.html就可以解决问题了在nginx上进行设置:try_files $uri $uri/ /test-daily/index.html 即可。至此,也就实现了所有的history模式的配置。在未设置mode:“history”,vue的路由默认是hash模式,地址栏中显示如下:hash:在地址栏中显示”#”符号(这里的hash不是密码学中的散列运算)。例如:localhost:8080/#/index,hash的值为#/index。它的特点在于:hash虽然出现在路径中,但是不会被包括在HTTP请求中,对后端完全没有影响,因此改变hash不会重新加载页面。history利用了免费云主机域名H5 history Interface中新增的pushState()和replaceState()方法。(需要特定浏览器支持)这两个方法应用于浏览器的历史记录栈,在当前已有的back、forward、go的基础上,它们提供了对历史记录进行修改的功能。只是当它们执行修改时,虽然改变了当前的Url,但是浏览器不会立即向后端发送请求。综上:hash模式和history模式都属于浏览器自身的特性,Vue-Router只是利用了这两个特性(通过调用浏览器提供的接口)来实现前端路由。为了使路径更加直观及美观,就需要使用history模式。只需在router文件夹下的index.js中加入 mode:“history”关于单页面交互跳转,只需要使用router提供的方法即可。在main.js文件配置中将router绑定到全局跳转页面如下:读到这里,这篇“vue-router怎么实现history模式配置”文章已经介绍完毕,想要掌握这篇文章的知识点还需要大家自己动手实践使用过才能领会,如果想了解更多相关内容的文章,欢迎关注百云主机行业资讯频道。

相关推荐: 怎么实现一个Kotlin函数类型

本免费云主机域名篇内容主要讲解“怎么实现一个Kotlin函数类型”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“怎么实现一个Kotlin函数类型”吧!业务开发中,经常会有实现一个函数式接口(即接口只有一个方法需要实现…

免责声明:本站发布的图片视频文字,以转载和分享为主,文章观点不代表本站立场,本站不承担相关法律责任;如果涉及侵权请联系邮箱:360163164@qq.com举报,并提供相关证据,经查实将立刻删除涉嫌侵权内容。

Like (0)
Donate 微信扫一扫 微信扫一扫
Previous 03/16 10:19
Next 03/16 10:31

相关推荐