Vue $nextTick

我们用一个例子来说明$nextTick的作用:

我们用一个变量showIpt来控制input框的显示和隐藏,默认是隐藏。

我们点击一个按钮后显示这个输入框的同时,input还要自动获取焦点。

但是我们点击按钮过后并没有生效。

为什么?this.showIpt=true执行过后接着就是执行this.$refs.ipt.focus() ,所有的代码执行完毕后将解析好的DOM放到页面上去。

也就是说,focus() 的时候DOM还没解析呢!

因此,我们就可以使用$nextTick() 来解决这个问题:

this.$nextTick( // 执行函数 )

$nextTick() 的作用就是在下一次DOM更新结束后执行其指定的回调。

当数据改变后,要对更新后的DOM进行一些操作时,就可以在$nextTick() 的回调函数中执行。

相关推荐
C_心欲无痕几秒前
使用 FNM (Fast Node Manager) 管理多个 Node.js 版本
前端·node.js
爬山算法3 分钟前
Hibernate(44)Hibernate中的fetch join是什么?
前端·python·hibernate
橙序员小站10 分钟前
解密前端包管理工具:npm、Yarn与pnpm的全面对比
前端·npm·node.js
m0_7482546612 分钟前
HTML DOM - 修改 HTML 内容的方法
前端·html
Jinuss12 分钟前
React16与React17+的JSX转换差异
前端·react.js
爱吃香菜i16 分钟前
数据连接开发设计文档
前端·javascript
冴羽19 分钟前
现代 CSS 颜色使用指南
前端·javascript·css
Rrvive19 分钟前
Vue3向全局广播数据变化
javascript·vue.js
cj814019 分钟前
动态表单与静态表单性能比较
前端
han_26 分钟前
为啥 Array.isArray 判断数组最靠谱?
前端·javascript