Element-ui+Vue 的el-menu菜单第二次点击刷新解决方案

在html页面<el-menu> 加上属性@select="handleSelect",如以下代码: 

                 <el-menu
                        :default-active="activeIndex"
                        :default-openeds="['1']"
                        @select="handleSelect">
                    <el-submenu index="1">
                        <template slot="title"><i class="el-icon-menu"></i>导航</template>
                        <el-menu-item index="1-1" v-if="is_show_user">
                            <router-link to="/listener" class="mens" tag="span">小程序使用监控</router-link>
                        </el-menu-item>
                      
                    </el-submenu>
                    </el-submenu>
                </el-menu>

 

1、修改router数组对象的item里面的component:{ template:'' },component.template 内容修改添加一个iframe 的ID,对应routers 里item的name,如name:listener,则iframe的ID为:iframe_listener;

2、在JS 添加vue的method 方法 handleSelect,如下:

Vue.prototype.axios = axios;
Vue.use(VueRouter);
const router = new VueRouter({
    routes: [        
        {
            path: '/listener',
            name: 'listener',
            component: {
                template: `
                   <div>
                   <iframe  id="iframe_listener"  src="../total/listener"></iframe>
                    </div>
   `
            }
        }

    ]
})
new Vue({
    el: "#app",
    router: router,
    created() {
        this.url = 'xxxx';
    },
    mounted() {},
    filters: {},
    methods: {
        handleSelect(key, keyPath){
            const this_=this;
            const date=new Date();
            const _url=document.getElementById("iframe_"+this._route.name).src;
            let _path=_url+'?t='+date.getTime();
            if(_url.indexOf('?')!= -1){
                _path= (_url.substr(0,_url.indexOf('?')))+'?t='+date.getTime();
            }
            document.getElementById("iframe_"+this._route.name).src=_path;
        }
    },

})

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 2
    评论
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

StephenYangKing

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

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

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

打赏作者

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

抵扣说明:

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

余额充值