vue3页面query参数变化并重新加载页面数据方式

 更新时间:2024年10月18日 09:20:13   作者:钢铁加lulu  
在Web开发中,页面间的跳转及数据刷新是常见问题,通过使用$router.push和$router.replace方法,可以控制页面跳转的行为,具体操作时,若发现页面ID变更后数据未刷新,可通过给router-view标签添加key值解决,若使用keep-alive

一、业务场景

列表页携带id跳转到详情页,id发生变化重新加载当前页面。

跳转分两种情况,假设A页面是id为1111的详情页,B页面是id为2222的详情页。

  • 第一种,A页面跳转到B页面,B页面返回时直接返回列表页。
  • 第二种,A页面跳转到B页面,B页面返回时返回A页面,A页面再返回返回到列表页。

二、实现方式

核心方法: $router.push $router.replace

A页面跳转到B页面的方法:

  • 第一种情况:
    import { useRouter } from 'vue-router'

    const router = useRouter()

    router.replace({
      path: '/eFileManagement/company/collection/detail',
      query: { id: '2222' }
    })
  • 第二种情况:
    import { useRouter } from 'vue-router'

    const router = useRouter()

    router.push({
      path: '/eFileManagement/company/collection/detail',
      query: { id: '2222' }
    })

三、发现问题

到第二步,我们需要的功能就已经实现了,但是会发现地址栏id是变化了,页面数据却并没有刷新,这时我们给App.vue里的router-view标签添加一个key值即可

如下:

<router-view :key="routerKey"></router-view>
import { useRoute } from 'vue-router'

const route = useRoute()

const routerKey = computed(() => {
  return route.path + Math.random()
})

OK!

延伸:(keep-alive)

如果router-view在keep-alive标签下,那么需要再给router-view加个状态值,用来控制router-view显示隐藏,并且provide注入,方便页面中调用。

App.vue:

<router-view :key="routerKey" v-if="isAlive"></router-view>
import { ref, provide, nextTick } from 'vue'

const isAlive = ref<boolean>(true)

function reload() {
    isAlive.value = false
    nextTick(() => {
        isAlive.value = true
    })
} 

provide('reload', reload)

A页面里:

import { inject } from 'vue'
const reload:any = inject('reload')

然后在push或者replace方法后调用reload方法。

    import { useRouter } from 'vue-router'

    const router = useRouter()

    router.push({
      path: '/eFileManagement/company/collection/detail',
      query: { id: '2222' }
    })

    reload()

总结

以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。

相关文章

  • Vue keep-alive组件的使用及如何清除缓存

    Vue keep-alive组件的使用及如何清除缓存

    本文介绍了Vue keep-alive组件的使用及如何清除缓存,给大家分享清除缓存的几种方法,结合实例代码给大家讲解的非常详细,需要的朋友跟随小编一起看看吧
    2023-10-10
  • vue使用echarts实现立体柱形图

    vue使用echarts实现立体柱形图

    这篇文章主要为大家详细介绍了vue使用echarts实现立体柱形图,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2022-04-04
  • 解决vue多层弹框时存在遮挡问题

    解决vue多层弹框时存在遮挡问题

    本文给大家介绍vue多层弹框时存在遮挡问题,解决思路首先想到的是找到对应的遮挡层的css标签,然后修改z-index值,但是本思路只能解决首次问题,再次打开还会存在相同的问题,故该思路错误,下面给大家带来一种正确的思路,一起看看吧
    2022-03-03
  • vue3实现tabs导航栏点击每个导航项有下划线动画效果

    vue3实现tabs导航栏点击每个导航项有下划线动画效果

    这篇文章主要介绍了vue3实现tabs导航栏点击每个导航项有下划线动画效果,本文通过实例代码给大家介绍的非常详细,感兴趣的朋友跟随小编一起看看吧
    2024-07-07
  • vue移动端弹框组件的实例

    vue移动端弹框组件的实例

    今天小编就为大家分享一篇vue移动端弹框组件的实例,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2018-09-09
  • vue使用async/await来实现同步和异步的案例分享

    vue使用async/await来实现同步和异步的案例分享

    近期项目中大量使用async,从服务器获取数据,解决一些并发传参问题,代码很简单,在此也看了一些博客,现在async/await已经大范围让使用,所以本文给大家介绍一下vue使用async/await来实现同步和异步的案例,需要的朋友可以参考下
    2024-01-01
  • vue+iview/elementUi实现城市多选

    vue+iview/elementUi实现城市多选

    这篇文章主要介绍了vue+iview/elementUi实现城市多选,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2019-03-03
  • Vue之Axios异步通信详解

    Vue之Axios异步通信详解

    这篇文章主要为大家介绍了Vue之Axios异步通信,具有一定的参考价值,感兴趣的小伙伴们可以参考一下,希望能够给你带来帮助
    2021-11-11
  • vue3使用reactive包裹数组正确赋值问题

    vue3使用reactive包裹数组正确赋值问题

    这篇文章主要介绍了vue3使用reactive包裹数组正确赋值问题,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2023-03-03
  • Vue组件通信实践记录(推荐)

    Vue组件通信实践记录(推荐)

    本篇文章主要介绍了Vue组件通信实践记录(推荐),小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2017-08-08

最新评论