时间:2021-05-26
前言:
在开发过程中,有时候会遇到这么一种情况,通过动态的赋值,但是dom没有及时更新,能够获取到动态赋的值,但是无法获取到双向绑定的dom节点,这就需要我们手动进行强制刷新组件。
官网是这样说的:
可能你还不大理解,请继续往下看,下面是我的一个例子,来详细解说了这个方法的使用,
第一个打印结果
第二个打印结果
一、问题描述:父组件通过v-for渲染子组件,删除子组件数据出现异常。
二、问题原因:出现异常的数据不是响应式依赖,是从vuex读取的。通过测试发现,父组件删除数据,没有重新创建子组件,怀疑是子组件异常的数据是读取的缓存副本。
三、问题解决:根据v-if改变dom结构的特性,手动使子组件重新创建。
1.设置一个数据变量isrefresh=true
2.初始v-if=isrefresh
3.删除时,配合$nextTick()DOM渲染回调函数,使子组件重新创建
/************************************************************************************************************************************/
PS:vue 强制刷新子组件
把一个组件重置到初始状态是一个常见的需求,推荐的做法有两种,一种是父组件重置子组件的 prop,另一种是子组件暴露一个重置的方法供父组件调用。但有些时候,子组件既没有提供重置的方法,也没提供 prop 来重置自己的状态。更重要的是,这个子组件我们还动不了。于是我们就需要一种 hack 的方式来强制子组件重置到初始状态。方法如下:
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
Vue通过直接强制刷新DOM来达到重置组件的效果,这样可以重置一些组件的动画以及组件内初始的数据强制重新生成DOM的实现原理:强制重新生成DOM可以通过Vue中
本文介绍了Vue树形组件的示例代码,分享给大家,具体如下:使用SemanticUI和vue做一个menubar组件,实现方法大概是这样的:0">{{item.t
本文介绍了vue父子组件的嵌套的示例代码,分享给大家,具体如下:组件的注册:先创建一个构造器varmyComponent=Vue.extend({templat
版权1、外层包围keep-alive作用将组件实例缓存下来2、清除组件缓存使用keep-alive的exclude="组件名"属性补充知识:vue简单的页面刷新
本文实例为大家分享了Vue2.0分页组件的具体实现代码,供大家参考,具体内容如下整个示例打包了,有需要的可以下载,有不对的地方欢迎指出:vue分页组件组件部分代