在使用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渲染已经完成')
   })
  }
 }
})
Logo

前往低代码交流专区

更多推荐