Vue 实现刷新当前页面

provide/inject实现祖先组件向其他子孙组件注入一个值

实例 祖先组件

<template>
  <div id="app">
  <!--通过v-if显隐控制路由重新渲染页面实现刷新-->
    <router-view v-if="isRouterAlive"></router-view>
  </div>
</template>

<script>
export default {
  name: 'App',
   //向组件外暴露一个
  provide() {
    return {
      //暴露名称 绑定的本组件属性
      reload: this.reload
    };
  },
  data() {
    return {
      //变量
      isRouterAlive: true
    };
  },
  methods: {
    //调用reload方法控制是否渲染
    reload() { 
      //变量赋值
      this.isRouterAlive = false;
        //;值的改变使DOM重新渲染,this.$nextTick(callback)
      this.$nextTick(function() {
        this.isRouterAlive = true;
      });
    }
  }
};
</script>

this.$nextTick(callback);

官方解释:将回调延迟到下次 DOM 更新循环之后执行在修改数据之后立即使用它,然后等待 DOM 更新。它跟全局方法 Vue.nextTick 一样,不同的是回调的 this 自动绑定到调用它的实例上。
个人理解:当数据或是其他因素变化引起的Dom更新时,直接读取和使用DOM的参与变化的值,可能得到的是更新前的,DOM没有更新完成;将要执行的代码放在this.$nextTick(callback)的callback中,会使其在DOM更新后执行,确保是新数据;

例: this.$nextTick(function() {
this.isRouterAlive = true;
});

子孙组件

export default {
    name: 'pickList',
    //在default下 与 data/watch/computed等同级位置注入,注入的字符串名字要与上面暴露的一致
    //然后在此组件的其他位置就可以调用了    this.reload();
    inject: ['reload'],
    computed: {
      getCancelId() {
      }
    },
    watch: {
      getCancelId(value) {
      }
    },
    data() {
      return {
       }
    }

官方建议:provide 和 inject 主要为高阶插件/组件库提供用例。并不推荐直接用于应用程序代码中。 2.2.0 新增
这对选项需要一起使用,以允许一个祖先组件向其所有子孙后代注入一个依赖,不论组件层次有多深,并在起上下游关系成立的时间里始终生效

provide:Object 或 () => Object 选项应该是一个对象或返回一个对象的函数。该对象包含可注入其子孙的属性
inject:Array<string> 或 { [key: string]: string | Symbol | Object } 这是去看vue.js官网吧一时写不明白,简单用自己理解的说下,应该是一个String类型的数组,或者是一个对象,当是数组时比较好理解直接是provide中暴露的属性名的字符传数组["a"],当是对象时 key是与本地绑定的值,值是字符串,或Symbol或是一个对象,当是字符串时与provide暴露的一致,当是Symbol时与provide暴露的Symbol一致;当是对象时,对象的两个key分别是 from 和default ,对应的值是provide暴露的(注入的内容) 字符串或 Symbol; 说不明白,以后加示例吧.

浪客行1213的简书


xhh
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 218,284评论 6 506
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 93,115评论 3 395
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 164,614评论 0 354
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 58,671评论 1 293
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 67,699评论 6 392
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 51,562评论 1 305
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 40,309评论 3 418
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 39,223评论 0 276
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 45,668评论 1 314
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,859评论 3 336
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,981评论 1 348
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,705评论 5 347
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 41,310评论 3 330
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,904评论 0 22
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 33,023评论 1 270
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 48,146评论 3 370
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,933评论 2 355

推荐阅读更多精彩内容

  • Vue 3.0 性能提升主要是通过哪几方面体现的? vue2在初始化的时候,对data中的每个属性使用define...
    Smallbore阅读 1,161评论 0 8
  • 前言 组件是 vue.js最强大的功能之一,而组件实例的作用域是相互独立的,这就意味着不同组件之间的数据无法相互引...
    用技术改变世界阅读 2,164评论 1 3
  • 访问元素 & 组件 在绝大多数情况下,我们最好不要触达另一个组件实例内部或手动操作 DOM 元素。不过也确实在一些...
    前端菜篮子阅读 729评论 0 0
  • 1.vue.js的两个核心是什么? vue.js的两个核心分别是数据驱动(MVVM)和组件化。 一、数据驱动 数据...
    fengcol阅读 1,067评论 0 3
  • 一:什么是闭包?闭包的用处? (1)闭包就是能够读取其他函数内部变量的函数。在本质上,闭包就 是将函数内部和函数外...
    xuguibin阅读 9,608评论 1 52