Vue 路由 跳转【返回、刷新、跳转】

本文详细介绍了Vue中路由导航的各种方法,包括this.$router.go用于前进、后退和刷新,this.$router.back实现后退和刷新,以及this.$router.push和this.$router.replace进行页面跳转。通过实例展示了它们的不同用法,包括参数传递和URL变化。了解这些方法对于掌握Vue应用的页面流动至关重要。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

Vue 路由 跳转【返回、刷新、跳转】

this.$router.go(-1)

原页面表单中的内容会丢失;
向前或者向后跳转n个页面,n可为正整数或负整数

this.$router.go(-1):后退+刷新

this.$router.go(0):刷新;

this.$router.go(1) :前进

this.$router.back()

原页表表单中的内容会保留

this.$router.back():后退 ;

this.$router.back(0) 刷新;

this.$router.back(1):前进

this.$router.push

跳转到指定url路径,并想history栈中添加一个记录,点击后退会返回到上一个页面

1. 不带参数

  • this.$router.push(’/home’)
  • this.$router.push({name:‘home’})
  • this.$router.push({path:’/home’})

2. query传参

  • this.$router.push({name:‘home’,query: {id:‘1’}})
  • this.$router.push({path:’/home’,query: {id:‘1’}})
  • html 取参 $route.query.id
    script 取参 this.$route.query.id

3. params传参

  • this.$router.push({name:‘home’,params: {id:‘1’}}) // 只能用 name
  • 路由配置 path: “/home/:id” 或者 path: “/home:id” ,
    不配置path ,第一次可请求,刷新页面id会消失
    配置path,刷新页面id会保留
    html 取参 $route.params.id
    script 取参 this.$route.params.id

4. query和params区别

  • query类似 get, 跳转之后页面 url后面会拼接参数,类似?id=1, 非重要性的可以这样传,
  • params类似 post, 跳转之后页面 url后面不会拼接参数 , 但是刷新页面id 会消失,密码之类还是用params刷新页面

this.$router.replace

跳转到指定url路径,但是history栈中不会有记录,点击返回会跳转到上上个页面 (就是直接替换了当前页面)【A----->B----->C 结果B被C替换 A----->C)】

用法同 this.$router.push
### Vue.js 路由跳转后页面刷新解决方案 在开发基于 Vue 的单页面应用程序 (SPA) 时,确保路由跳转过程中页面不会意外刷新至关重要。当遇到路由跳转导致页面刷新的问题时,通常是因为服务器端未正确配置静态资源加载路径或缺少必要的前端路由模式设置。 #### 使用 HTML5 History Mode 配置 默认情况下,Vue Router 使用哈希模式 (`/#`) 来模拟完整的 URL 结构而无需重新加载页面。如果希望移除地址栏中的 `#` 符号并启用更自然的 URL 形式,则应采用 HTML5 history 模式: ```javascript const router = new VueRouter({ mode: 'history', // 启用HTML5历史记录API routes: [ // 定义路由... ] }) ``` 此配置使得浏览器能够利用 pushState 和 replaceState API 实现无刷新导航[^1]。 #### Nginx 或 Apache 服务端配置调整 为了使 HTML5 history 模式正常工作,在部署至生产环境前还需对 Web 服务器进行适当配置。对于 Nginx 用户来说,可以通过如下方式处理未知请求转发给 index.html 文件: ```nginx location / { try_files $uri $uri/ /index.html; } ``` Apache 则可以使用 `.htaccess` 文件来达到相同效果: ```apacheconf <IfModule mod_rewrite.c> RewriteEngine On RewriteBase / RewriteRule ^index\.html$ - [L] RewriteCond %{REQUEST_FILENAME} !-f RewriteCond %{REQUEST_FILENAME} !-d RewriteRule . /index.html [L] </IfModule> ``` 这些更改确保即使用户直接访问某个内部链接或者刷新页面也不会返回 404 错误而是被导向到 SPA 应用入口处[^3]。 #### 组件内监听 `$route` 变化 有时即便解决了上述问题仍然可能出现特定场景下的页面闪烁现象。这可能是由于组件未能及时响应新的路由参数所引起。此时可在组件中添加 watcher 监视器以捕捉路由变动事件,并据此执行相应逻辑更新界面状态: ```typescript <script lang="ts"> import { Component, Vue, Watch } from 'vue-property-decorator' @Component({}) export default class MyComponent extends Vue { @Watch('$route') onRouteChange(to: Route, from: Route): void { console.log('Route changed:', to.path); this.fetchData(); // 假设这是一个获取数据的方法 } fetchData(): void { // 数据拉取逻辑... } } </script> ``` 这种方法允许开发者针对每次成功的路由转换做出反应,从而避免不必要的页面重载行为[^5]。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

半生过往

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

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

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

打赏作者

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

抵扣说明:

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

余额充值