vue刷新当前路由

1、首先创建一个空白界面,空白界面输入写入如下代码

<template>
    <div></div>
</template>
<script>
import {mapState} from 'vuex'
export default {
    name:"Blank",
    data(){
        return{
            flag : true
        }
    },
    created() {
        if(this.flag){
            this.flag = false;
        }
        this.returnPage();
    },
    methods:{
        returnPage(){
            let url = this.$route.query;//获取传递过来的路由信息
            let str = '';
            for(let i in url) {
                str += url[i];
            }
            //获取上个界面的name值
            let fromName = str.split("/")[1];
            fromName = fromName.charAt(0).toUpperCase() + fromName.slice(1);
            //获取上个界面的name值
            //清除上个界面的keepAlive缓存
            let newKeepAlive = [];
            for (let i in this.keepAlive) {
                const item = this.keepAlive[i];
                if(item != fromName){
                    newKeepAlive.push(item);
                }
            }
            this.$store.dispatch("changeKeepAlive",newKeepAlive);
            //清除上个界面的keepAlive缓存
            setTimeout(()=>{//时间不要设置过长
                this.$router.push({
                    path: str,
                });
            },10);
        }
    },
    activated(){//当前路由激活时触发
        if(!this.flag){//如果是第一次进入此界面,也会执行created路由,顾需判断
            this.flag = true;
            return;
        }
        this.returnPage();
    },
    computed:{
        ...mapState(['keepAlive'])
    }
}
</script>

2、点击刷新路由图标时

this.$router.push({
    path: '/blank',
    query: this.$route.path
})

3、效果

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

Agwenbi

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

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

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

打赏作者

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

抵扣说明:

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

余额充值