阿巴阿巴29 2023-10-14 20:55 采纳率: 0%
浏览 8

$router.push跳转后消除当前组件

在使用this.$router.push("/login")时,当前组件和目标组件同时显示,地址栏是目标组件的

  • 写回答

1条回答 默认 最新

  • CSDN-Ada助手 CSDN-AI 官方账号 2023-10-14 23:20
    关注

    【以下回答由 GPT 生成】

    解决方案

    要实现在使用this.$router.push("/login")进行跳转时,同时消除当前组件,只显示目标组件,并且地址栏显示目标组件的地址,可以采取以下步骤:

    1. 在当前组件的<template>中,使用<router-view>标签将目标组件包裹起来,确保目标组件能够在当前组件中进行渲染。
    2. 在当前组件的<script>中,使用this.$router.replace("/login")来替代this.$router.push("/login")replace方法会替换掉当前的历史记录,而不是添加新的历史记录,从而达到消除当前组件的效果。
    3. 在Vue Router的配置文件中,通过mode: "history"来设置路由模式为history模式,这样在地址栏中只会显示目标组件的地址,而不会显示历史记录。

    示例代码如下:

    <!-- 当前组件 -->
    <template>
      <div>
        <router-view></router-view>
      </div>
    </template>
    
    <script>
    export default {
      methods: {
        goToLogin() {
          // 使用replace方法替代push方法
          this.$router.replace("/login");
        }
      }
    }
    </script>
    
    // Vue Router 配置文件
    import Vue from 'vue'
    import Router from 'vue-router'
    
    Vue.use(Router)
    
    export default new Router({
      mode: "history",
      routes: [
        {
          path: "/login",
          name: "Login",
          component: Login
        },
        // 其他路由配置
      ]
    })
    

    这样,当调用goToLogin方法时,当前组件会被消除,只显示目标组件,并且在地址栏中只会显示目标组件的地址。



    【相关推荐】



    如果你已经解决了该问题, 非常希望你能够分享一下解决方案, 写成博客, 将相关链接放在评论区, 以帮助更多的人 ^-^
    评论

报告相同问题?

问题事件

  • 创建了问题 10月14日

悬赏问题

  • ¥15 校内二手商品转让网站
  • ¥20 高德地图聚合图层MarkerCluster聚合多个点,但是ClusterData只有其中部分数据,原因应该是有经纬度重合的地方点,现在我想让ClusterData显示所有点的信息,如何实现?
  • ¥100 求Web版SPC控制图程序包调式
  • ¥20 指导如何跑通以下两个Github代码
  • ¥15 大家知道这个后备文件怎么删吗,为啥这些文件我只看到一份,没有后备呀
  • ¥15 C++为什么这个代码没报错运行不出来啊
  • ¥15 一道ban了很多东西的pyjail题
  • ¥15 关于#r语言#的问题:如何将生成的四幅图排在一起,且对变量的赋值进行更改,让组合的图漂亮、美观@(相关搜索:森林图)
  • ¥15 C++识别堆叠物体异常
  • ¥15 微软硬件驱动认证账号申请