标签:nextTick 容器 DOM 更新 获取 echarts
在Vue中,数据的更新不会马上同步到视图上,而是放在一个异步更新队列中,在下一个事件循环tick集中更新。
由于这个机制,我们如果想在基于更新后的DOM状态做点什么,就没办法在更新数据后马上获取DOM,因此为此时数据还未同步到视图上。而Vue提供了nextTick(),它可以传入一个回调函数,这个回调函数将在DOM更新之后被调用。
举一个例子:使用echarts时,获取到数据之前,echarts容器(div元素或canvas元素)是通过v-if=false隐藏的,取而代之的是一个loading或自定义的元素。当数据获取完毕时,调整v-if=true显示echarts容器,然后通过$refs获取这个容器进行echart的实例化。而将v-if的值从false置为true的那一个tick内,DOM是没有发生变化的,是获取不到那个echarts容器的,此时就得使用Vue.nextTick()到下一个tick获取echarts容器。
标签:nextTick,容器,DOM,更新,获取,echarts 来源: https://www.cnblogs.com/hdxg/p/16697317.html
本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享; 2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关; 3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关; 4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除; 5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。