Vue在监听到数据改变或者dom元素渲染完之后执行的回调函数

在使用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渲染已经完成')
   })
  }
 }
})
  • 2
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值