Vue在监听到数据改变或者dom元素渲染完之后执行的回调函数
<ul id="demo"><li v-for="item in list">{{item}}</div></ul>new Vue({el:'#demo',data:{list=[0,1,2,3,4,5,6,7,8,9,10]},methods:{push:function(){this.list.push(11);this.nextTick(fun
·
在使用vue开发时遇到了一个问题,修改玩vue的data数据之后,操作dom,却发现没有改变,操作的dom还是之前的dom,后来在测试延时操作dom发现可以实现操作更新之后的dom了。从网上查询资料发现是vue对象在更改完值之后然后去渲染dom元素,我执行的代码发生在了vue还没渲染完成的时候,因此会拿不到更新后的dom,解决办法为使用 $nextTick()方法,这是vue在值改变时进行dom渲染完成之后的回调函数,具体使用如下例:在控制台执行push()方法就可以看到效果了
<div id="app" >
<ul>
<li v-for="item in list" >
{{item}}
</li>
</ul>
</div>
var myVue = new Vue({
el:'#app',
data:{
list:[0,1,2,3,4,5,6,7,8,9,10]
},
methods:{
push:function(){
this.list.push(11);
this.$nextTick(function(){
console.log('v-for渲染已经完成')
})
}
}
})
更多推荐
已为社区贡献1条内容
所有评论(0)