vue 路由参数刷新页面状态保持_参数顺序不同算重载吗

vue 路由参数刷新页面状态保持_参数顺序不同算重载吗针对Vue相同路由不同参数的刷新问题

大家好,又见面了,我是你们的朋友全栈君。

在使用vue和vue-router开发spa应用时,我们会遇到这样一种问题。
当页面跳转时,组件本身并没有发生改变:

// 路由映射关系'/form/:type'
// 当前页面路由/form/shop1
this.$router.push({ name: 'form', params: { type: 'shop2' })

这时我们进行路由跳转后会发现组件并没有刷新,在前一个路由组件的数据都保留了下来,这并不是我们想要的效果。

对于简单的数据更新,我们可以直接监听路由参数并重新获取路由的初始化数据即可,
但是对于有很多子组件需要初始化或者reset的情况,我们还是有必要重新执行组件的生命周期。

针对这种情况可以使用三种方式解决:

1.为相同路由页面的跳转进行中间路由替换,在router上注册
beforeEach全局守卫进行拦截,跳转到一个中间路由(例如empty),再从中间过渡路由跳转至要去的路由。

// 全局导航守卫
router.beforeEach((to, from, next) => {
    if (to.name === from.name && to.params.type !== from.params.type) {
        next({ name: 'empty', query: { toPath: to.fullPath } })
    } else {
        next()
    }
})

// 中间过渡路由
let toPath = this.$route.query.toPath
if (this.toPath) {
   this.$router.push({ path: this.toPath })
}

2.使用v-if重新渲染当前页面组件

// html部分
<div>
    <router-view v-if="showRouterView"/>
</div>

// script部分
export default {
   data () {
       return {
           isRouterAlive: true
       }
   },
   methods: {
       reload () {
           this.showRouterView = false
           this.$nextTick(() => (this.showRouterView = true))
       }   
   }
}

这样把方法注册到根组件上,对于想刷新的组件直接调用reload方法即可。

3.使用vue文档组件绑定的key值来进行强制刷新

vue文档说明了当你需要

  • 完整地触发组件的生命周期钩子
  • 触发过渡

的时候可以利用更新组件绑定的key值来完成更详细的说明

这样直接为组件绑定与路由参数关联的值即可

<MyComponent :key="routeParams" />

综合来看,第三种方式最简单,推荐使用。

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/107285.html原文链接:https://javaforall.net

(0)
上一篇 2022年4月20日 下午6:00
下一篇 2022年4月20日 下午6:00


相关推荐

  • 线性代数笔记9——消元矩阵与置换矩阵

    线性代数笔记9——消元矩阵与置换矩阵消元矩阵 如果用矩阵表示一个有解的方程组 那么矩阵经过消元后 最终能变成一个上三角矩阵 U 用一个三元一次方程组举例 A 经过一些列变换 最终得到了一个上三角矩阵 U nbsp 回代到方程组后可以直接求解 nbsp 如果上面的变换去掉增广矩阵 可以简写为 矩阵的初等变换可以用矩阵乘法实现 现在的问题是 我们能否得到一个可以表示整个消元过程的矩阵 E 使得 E 与 A 相乘能够

    2026年3月18日
    2
  • 作为一个程序员,什么是脚本。必须要理解「建议收藏」

    作为一个程序员,什么是脚本。必须要理解「建议收藏」Javascript是一门动态类型、面向对象的脚本语言。对脚本进行一个感性的认识。就是一个跟计算机执行的文本。理解脚本如果你打开一本JavaScript教程,那么很可能在第一章就看到这句话

    2022年8月2日
    6
  • pycharm 激活码(注册激活)

    (pycharm 激活码)2021最新分享一个能用的的激活码出来,希望能帮到需要激活的朋友。目前这个是能用的,但是用的人多了之后也会失效,会不定时更新的,大家持续关注此网站~https://javaforall.net/100143.htmlIntelliJ2021最新激活注册码,破解教程可免费永久激活,亲测有效,上面是详细链接哦~ML…

    2022年3月21日
    1.2K
  • response的意思_openresty源码解析

    response的意思_openresty源码解析源码目录结构get_uniform_comparator作用:将比较器别名转换为统一名称ifcomparatorin["eq","equals",

    2022年7月29日
    10
  • dll签名两种方法(转载)

    dll签名两种方法(转载)dll 签名两种方法下面两种签名方法 都是对 csp dll 签名 都不是 CA 颁发的 且效果不同 一 通过自建证书签名下载 windowssdk 安装成功后 包含 makecert exe cert2spc exe pvk2pfx exe signtool exe 工具 将要签名的 csp dll 也放入工具目录 cmd 命令切换到工具目录 再执行以下命令 1 生成签名证书 makecert

    2026年3月16日
    3
  • 2021.7 goland 激活码[免费获取]

    (2021.7 goland 激活码)2021最新分享一个能用的的激活码出来,希望能帮到需要激活的朋友。目前这个是能用的,但是用的人多了之后也会失效,会不定时更新的,大家持续关注此网站~IntelliJ2021最新激活注册码,破解教程可免费永久激活,亲测有效,下面是详细链接哦~https://javaforall.net/100143.html…

    2022年3月21日
    84

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号