vue强制刷新组件的方法示例
网络编程 2021-07-04 15:50www.168986.cn编程入门
这篇文章主要介绍了vue强制刷新组件的方法示例,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们狼蚁网站SEO优化随着长沙网络推广来一起学习学习吧
前言
在开发过程中,有时候会遇到这么一种情况,通过动态的赋值,dom没有及时更新,能够获取到动态赋的值,无法获取到双向绑定的dom节点,这就需要我们手动进行强制刷新组件。
官网是这样说的
可能你还不大理解,请继续往下看,狼蚁网站SEO优化是我的一个例子,来详细解说了这个方法的使用,
第一个打印结果
第二个打印结果
一、问题描述父组件通过v-for渲染子组件,删除子组件数据出现异常。
<code class="language-plain"><section v-if="isrefresh" v-for="(sign,index) in signs"> <sign-card></sign-card> </section></code>
二、问题原因出现异常的数据不是响应式依赖,是从vuex读取的。通过测试发现,父组件删除数据,没有重新创建子组件,怀疑是子组件异常的数据是读取的缓存副本。
三、问题解决根据v-if改变dom结构的特性,手动使子组件重新创建。
1.设置一个数据变量isrefresh=true
2.初始v-if=isrefresh
3.删除时,配合$nextTick()DOM渲染回调函数,使子组件重新创建
//
PSvue 强制刷新子组件
把一个组件重置到初始状态是一个常见的需求,推荐的做法有两种,一种是父组件重置子组件的 prop,另一种是子组件暴露一个重置的方法供父组件调用。但有些时候,子组件既没有提供重置的方法,也没提供 prop 来重置自己的状态。更重要的是,这个子组件我们还动不了。于是我们就需要一种 hack 的方式来强制子组件重置到初始状态。方法如下
// 原理就是采用v-if会销毁组件并且重绘,这样就会重载组件 // 子组件自己封装的组件 <IneStatistics v-if="DestroyIneStatistics == true" ref="IneStatisticsChild"></IneStatistics> // 然后再父组件内的增删改查方法中操作,就好了 this.DestroyIneStatistics = false; // 然后你的方法成功后 // Vue 实现响应式并不是数据发生变化之后 DOM 立即变化,而是按一定的策略进行 DOM 的更新。 // 在vue的深入响应式原理中有解释 // $nextTick 是在下次 DOM 更新循环结束之后执行延迟回调,在修改数据之后使用 $nextTick,则可以在回调中获取更新后的 DOM this.$nextTick(() => { this.DestroyIneStatistics = true; }); //这样的话就会完成强制刷新
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持狼蚁SEO。
编程语言
- 宿迁百度关键词排名指南:实现精准营销的关键
- 四川SEO优化怎么做网络推广
- 立昂技术备案老域名收购:如何为您的业务赋能
- 安徽百度关键词seo贵不贵,一般需要多少钱
- 吉林百度快照排名怎么做电话营销
- 多伦新手做SEO怎么做
- 甘肃优化关键词排名推广怎么做论坛营销
- 沙雅SEO网站推广:提升您的在线可见性
- 四川SEO优化如何提升销售额和销售量
- 聂荣网站排名优化:提升网站可见性的全方位指
- 涞水SEO:提升地方企业在线可见性的策略
- 辽宁百度seo排名怎样做网站排名
- 临湘哪有关键词排名优化:提升网站可见度的关
- 黑龙江百度网站优化有没有优惠
- 凉城优化关键词排名推广:提升您的网络可见性
- 萝北整站优化:提升您网站流量和排名的全面指