this.$route和this.$router区别--hash&history模式

  1. this.$router:

表示全局路由器对象,项目中通过router路由参数注入路由之后,在任何一个页面都可以通过此方法获取到路由器对象,并调用其push(), go()等方法;
跳转到哪里,用router.push

  1. this.$route:

表示当前正在用于跳转的路由器对象,可以调用其name、path、query、params等方法;


1.hash,window.hashchange
url中带有#不是很美观,根据#后面跳转,不请求服务器
const router = new VueRouter({
routes,
})

首先需要改动的关键位置
vue.config.js的publicPath
在这里插入图片描述

axios的baseURL
在这里插入图片描述

route.js的base
在这里插入图片描述

nginx配置
在这里插入图片描述

2.history. pushstate、replacestate
有时刷新404,所以要设置404页面。
url
const router = new VueRouter({
routes,
mode:“history”
})

通过history api,我们丢掉了#,但是它也有个问题:不怕前进,不怕后退,就怕刷新,f5,(如果后端没有准备的话),因为刷新是实实在在地去请求服务器的。在hash模式下,前端路由修改的是#中的信息,⽽浏览器请求时不会将 # 后⾯的数据发送到后台,所以没有问题。但是在history下,你可以⾃由的修改path,当刷新时,如果服务器中没有相应的响应或者资源,则会刷新出来404页⾯。

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

前端段

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值