vue项目刷新当前页

栏目: JavaScript · 发布时间: 6年前

内容简介:当在vue项目中需要刷新当前页时,第一个是不是想到this.$router.push(当前页面的路径)?但是你会发现,这样并没有什么用。因为基于vue这个框架,它发现当前路由没有改变,它并不会刷新。或者

当在vue项目中需要刷新当前页时,第一个是不是想到this.$router.push(当前页面的路径)?

但是你会发现,这样并没有什么用。因为基于vue这个框架,它发现当前路由没有改变,它并不会刷新。

解决方法1

this.$router.go(0)

或者

window.location.href()

这两种方式本质上就是重新刷新了整个页面而且随着项目业务的复杂程度,很可能会增加一些别的初始化请求,所以这并不是最优解。

解决方法2

思路是新增一个空白页,当需要执行刷新先跳转到空白页,再快速跳转回来。

实现起来很简单,我就不贴上代码了。

解决方法3

这个方法最方便快捷,连空白页的组件也不需要写。

这里用到了vue框架的provide和inject

在父组件中注入以来provide一个对象,在子组件中inject。

1、在APP.vue 页面加一个条件渲染,默认为true

<template>
  <div id="app">
    <router-view v-if="noRefresh" />
  </div>
</template>
<script>
export default {
  name: 'App',
  provide() {
    return {
      reload: this.reload
    }
  },
  data() {
    return {
      noRefresh: true
    }
  },
  methods:{
    // 需要reload时先将页面隐藏,在dom更新后的回调再将页面显示
    reload() {
      this.noRefresh = false
      this.$nextTick(function(){
        this.noRefresh = true
      })
    }
  }
}
</script>

子组件

<script>
export default {
    inject:['reload'],
    methods:{
        func(){
            //刷新时执行的函数
            this.reload()
        }
    }
}
</script>

以上就是本文的全部内容,希望本文的内容对大家的学习或者工作能带来一定的帮助,也希望大家多多支持 码农网

查看所有标签

猜你喜欢:

本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们

网站搜索设计

网站搜索设计

[美] Shari Thurow、[美] Nick Musica / 向怡宁 / 人民邮电出版社 / 2011-4 / 35.00

本书是提高网站搜索可用性的红宝书,它将SEO 和Web 可用性两个不同领域的知识融会贯通,详细阐述了用户的各种搜索行为和行为背后的真实意图,以及网站如何迎合用户心理,以便提供令其满意的内容,进而实现网站所有者的商业目标。 本书不仅仅是SEO 专业人员和Web 可用性人员的参考必备,同时更可为网络文案、设计开发人员、营销专员以及网站所有者、管理者等其他Web 领域从业人员拓展视野、补强技能。一起来看看 《网站搜索设计》 这本书的介绍吧!

随机密码生成器
随机密码生成器

多种字符组合密码

HTML 编码/解码
HTML 编码/解码

HTML 编码/解码

UNIX 时间戳转换
UNIX 时间戳转换

UNIX 时间戳转换