当前位置:编程学习 > > 正文

vue 修改后刷新(Vue使用三种方法刷新页面)

时间:2021-11-04 19:49:44类别:编程学习

vue 修改后刷新

Vue使用三种方法刷新页面

我们在写项目的时候,经常会遇到,用户执行完某个动作,改变了某些状态,需要重新刷新页面,以此来重新渲染页面。如:用户登录成功、增加、删除、更新等。

  • location.reload();
    
  • this.$router.go(0);
    
  • 用过的人都知道,前两者都是强制刷新页面,会出现短暂的闪烁,用户体验效果不好。
    所以,我们选择第三种方式:

  • <template>
        <li id="app">
        	<router-view v-if="isRouterAlive"></router-view>
    	</li>
    </template>
    <script>
        export default {
            name: 'App',
            provide () {    //父组件中通过provide来提供变量,在子组件中通过inject来注入变量。                                             
                return {
                    reload: this.reload                                              
                }
            },
            data() {
                return{
                    isRouterAlive: true                    //控制视图是否显示的变量
                }
            },
            methods: {
                reload () {
                    this.isRouterAlive = false;            //先关闭,
                    this.$nextTick(function () {
                        this.isRouterAlive = true;         //再打开
                    }) 
                }
            },
        }
    </script>
    
  • 接下来,我们就可以在需要刷新页面的组件里这样写:

  • export default {
        inject:['reload'],                                 //注入App里的reload方法
        data () {
            return {
        	.......
            }
        },
    
    
  • 在需要刷新页面的代码块中使用:

    到此这篇关于Vue使用三种方法刷新页面的文章就介绍到这了,更多相关Vue刷新页面内容请搜索开心学习网以前的文章或继续浏览下面的相关文章希望大家以后多多支持开心学习网!

    标签:
    上一篇下一篇

    猜您喜欢

    热门推荐