Loading [MathJax]/jax/output/CommonHTML/config.js
前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
社区首页 >专栏 >Vue.nextTick 的应用解析

Vue.nextTick 的应用解析

原创
作者头像
Krry
修改于 2020-03-09 02:21:47
修改于 2020-03-09 02:21:47
7720
举报
文章被收录于专栏:KrryblogKrryblog

博客地址:https://ainyi.com/86

问题背景

在弹窗表单里,经常关闭打开要重置整个表单,使用 this.$refs.addForm.resetFields()

但是如果第一次打开弹窗的时候,是通过点击==修改==打开的,在==this.dialogVisible = true==之前表单数据已经被要修改的数据初始化,此时的重置表单方法==resetFields()==,就会默认重置为第一次点击修改的那条数据。而不是重置为在 data 里初始化的数据

造成这个原因就是 因为弹窗视图被挂载到 dom 之前,又被执行了一次数据初始化(此时并非 data 里的数据),那么表单组件就会把挂载 dom 之前最近一次的数据作为初始化数据

解决方法是使用 this.$nextTick()

官方解释:

Vue 在更新 DOM 时是异步执行的,为了在数据变化之后等待 Vue 完成更新 DOM,可以在数据变化之后立即使用 Vue.nextTick(callback)。这样回调函数将在 DOM 更新完成后被调用

应用场景及原因

1. 在 Vue 生命周期的 ==created()== 钩子函数进行的 DOM 操作一定要放在 Vue.nextTick() 的回调函数中

原因:在 created() 钩子函数执行的时候 DOM 其实并未进行任何渲染,而此时进行 DOM 操作无异于徒劳,所以此处一定要将 DOM 操作的 js 代码放进 Vue.nextTick() 的回调函数中。与之对应的就是 mounted() 钩子函数,因为该钩子函数执行时所有的 DOM 挂载和渲染都已完成,此时在该钩子函数中进行任何 DOM 操作都不会有问题

2. 在数据变化后要执行的某个操作,而这个操作需要使用随数据改变而改变的DOM结构的时候,这个操作都应该放进 ==Vue.nextTick()== 的回调函数中

原因:Vue 异步执行 DOM 更新。只要观察到数据变化,Vue 将开启一个队列,并缓冲在同一事件循环中发生的所有数据改变。如果同一个 watcher 被多次触发,只会被推入到队列中一次。这种在缓冲时去除重复数据对于避免不必要的计算和 DOM 操作上非常重要。然后,在下一个的事件循环 “tick” 中,Vue 刷新队列并执行实际 (已去重的) 工作。Vue 在内部尝试对异步队列使用原生的==Promise.then==和==MessageChannel==,如果执行环境不支持,会采用 ==setTimeout(fn, 0)== 代替

例如,当你设置 vm.someData = 'new value',该组件不会立即重新渲染。当刷新队列时,组件会在事件循环队列清空时的下一个 “tick” 更新。多数情况我们不需要关心这个过程,但是如果你想在 DOM 状态更新后做点什么,这就可能会有些棘手。虽然 Vue.js 通常鼓励开发人员沿着==数据驱动==的方式思考,避免直接接触 DOM,但是有时我们确实要这么做。为了在数据变化之后等待 Vue 完成更新 DOM ,可以在数据变化之后立即使用 Vue.nextTick(callback) 。这样回调函数在 DOM 更新完成后就会调用

==简单来说 Vue.nextTick 就是用于延迟执行一段代码==

应用例子

如下应用例子:

代码语言:txt
AI代码解释
复制
openDialig(row) {
  this.dialogVisible = true
  if (row) {
    this.$nextTick(() => {
      this.addForm = _.pick(row, Object.keys(this.addForm))
    })
    this.isEdit = true
  } else {
    this.isEdit = false
    this.$nextTick(() => {
      this.$refs.addForm.resetFields()
    })
  }
}

博客地址:https://ainyi.com/86

原创声明:本文系作者授权腾讯云开发者社区发表,未经许可,不得转载。

如有侵权,请联系 cloudcommunity@tencent.com 删除。

原创声明:本文系作者授权腾讯云开发者社区发表,未经许可,不得转载。

如有侵权,请联系 cloudcommunity@tencent.com 删除。

评论
登录后参与评论
暂无评论
推荐阅读
编辑精选文章
换一批
Vue.nextTick 的原理和用途
Vue 实现响应式并不是数据发生变化之后 DOM 立即变化,而是按一定的策略进行 DOM 的更新。
青梅煮码
2023/03/02
5300
浅析$nextTick和$forceUpdate
vue中提供了数十种api供我们开发者日常使用,而常用的其实也就十多种,比如setup, mount, forceupdate, nextTick, compute, ref等,这些参数有的是在生命周期中进行管理,有的是在页面执行过程中,更新参数,有些是可以用来检测页面数据,这些随着项目的推进或多或少都是会使用到。其中nextTick和forceUpdate都是用来更新参数的,那这两个参数有什么差异呢?这还真值得仔细琢磨。
Yerik
2022/04/05
1.9K0
vue归纳笔记:对vue中nextTick()的理解及应用场景说明
请记住:vue是依靠数据驱动视图更新的,该更新的过程是异步的。即:当侦听到你的数据发生变化时, Vue将开启一个队列(该队列被Vue官方称为异步更新队列)。视图需要等队列中所有数据变化完成之后,再统一进行更新。
用户1272076
2019/06/13
9540
关于vue中$nextTick的一点使用心得
当下公司在做一个媒体门户网站,后台由另一家公司使用java开发并提供接口,本人负责开发后台页面,使用的是vue-element-admin开发 下面说一下问题场景,在开发过程中有一个后台管理员角色页面,其中包含一个表单dialog,在其中使用了el-tree组件,相关 代码结构如下: <div class="filter-container"> <el-button class="filter-item" style="margin-left: 10px;" v-waves @click="hand
lestat
2018/04/17
2.2K0
Vue面试题-03
前言 马上要秋招了,搜集整理了一些Vue面试题,包括组件、指令、API等相关内容,巩固基础😎秋招冲冲冲!!!本篇包括: ✅keep-alive的理解 ✅nextTick的理解 ✅vue组件之间的通信方式 ✅Vuex的理解及使用场景 keep-alive的理解 Props: include - string | RegExp | Array。只有名称匹配的组件会被缓存。 exclude - string | RegExp | Array。任何名称匹配的组件都不会被缓存。 max - number |
客怎眠qvq
2022/11/01
2.5K0
面试题:Vue中$nextTick原理
 在做项目的时候,我们经常会用到nextTick,简单的理解就是它就是一个setTimeout函数,将函数放到异步后去处理;将它替换成setTimeout好像也能跑起来,但它仅仅这么简单吗?那为什么我们不直接用setTimeout呢?让我们深入剖析一下。
前端迷
2020/05/26
6.1K0
面试题:Vue中$nextTick原理
Vue异步更新队列及nextTick
vue通常鼓励开发人员沿着“数据驱动”的方式思考,避免直接接触 DOM。Vue的dom更新是异步的,当数据发生变化,vue并不是里面去更新dom,而是开启一个队列。跟JavaScript原生的同步任务和异步任务相同。
wade
2020/04/24
7790
2022 最新 Vue 3.0 面试题
Vue 作为一款轻量级框架、简单易学、双向数据绑定、组件化、数据和结构的分离、虚拟 DOM、运行速度快,并且作者是中国人尤雨溪,对应的 API 文档对国内开发者优化,作为前端 开发人员的首选入门框架 Vue 的优势: 1、Vue.js 可以进行组件化开发,使代码编写量大大减少,读者更加易于理解。 2、Vue.js 最突出的优势在于可以对数据进行双向绑定。 3、使用 Vue.js 编写出来的界面效果本身就是响应式的,这使网页在各种设备上都能 显示出非常好看的效果。 4、相比传统的页面通过超链接实现页面的切换和跳转,Vue 使用路由不会刷新页 面。 5、vue 是单页面应用,使页面局部刷新,不用每次跳转页面都要请求所有数据和 dom,这样大大加快了访问速度和提升用户体验。 6、而且他的第三方 UI 组件库使用起来节省很多开发时间,从而提升开发效率。
猫头虎
2024/04/07
1670
Vue中的nexTick()
获取更新后的DOM言外之意就是,操作需要用到了更新后的DOM而不能使用之前的DOM或者使用更新前的DOM会出问题,所以就衍生出了这个获取更新后的 DOM的Vue方法。所以放在Vue.nextTick()回调函数中的执行的应该是会对DOM进行操作的 JS代码。
刘亦枫
2020/03/19
1.6K0
面试官:Vue中的$nextTick怎么理解?
我们可以理解成,Vue 在更新 DOM 时是异步执行的。当数据发生变化,Vue将开启一个异步更新队列,视图需要等队列中所有数据变化完成之后,再统一进行更新
@超人
2021/02/26
1.4K0
面试官:Vue中的$nextTick怎么理解?
Vue.nextTick核心原理
相信大家在写vue项目的时候,一定会发现一个神奇的api,Vue.nextTick。为什么说它神奇呢,那是因为在你做某些操作不生效时,将操作写在Vue.nextTick内,就神奇的生效了。那这是什么原因呢?
yyds2026
2022/10/18
5620
SSM 单体框架 - 前端开发:用户和权限模块
在查询条件中使用了 Element UI 中的日期选择器:https://element.eleme.cn/#/zh-CN/component/date-picker#mo-ren-xian-shi-ri-qi
RendaZhang
2020/10/09
1.7K0
SSM 单体框架 - 前端开发:用户和权限模块
VUE 异步更新队列 - $nextTick()
Vue 在更新 DOM 时是异步执行的。只要侦听到数据变化,Vue 将开启一个队列,并缓冲在同一事件循环中发生的所有数据变更。如果同一个 watcher 被多次触发,只会被推入到队列中一次。这种在缓冲时去除重复数据对于避免不必要的计算和 DOM 操作是非常重要的。然后在下一个的事件循环 “tick” 中,Vue 刷新队列并执行实际 (已去重的) 工作。Vue 在内部对异步队列尝试使用原生的 Promise.then、MutationObserver 和 setImmediate,如果执行环境不支持,则会采用 setTimeout(fn, 0) 代替。
用户7043603
2022/02/26
8840
Vue.$nextTick的原理是什么-vue面试进阶
原理性的东西就会文字较多,请耐下心来,细细品味Vue中DOM更新机制当你气势汹汹地使用Vue大展宏图的时候,突然发现,咦,我明明对这个数据进行更改了,但是当我获取它的时候怎么是上一次的值(本人比较懒,就不具体举例了👵)此时,Vue就会说:“小样,这你就不懂了吧,我的DOM是异步更新的呀!!!”简单的说,Vue的响应式并不是只数据发生变化之后,DOM就立刻发生变化,而是按照一定的策略进行DOM的更新。这样的好处是可以避免一些对DOM不必要的操作,提高渲染性能。在Vue官方文档中是这样说明的:可能你还没有注意到
bb_xiaxia1998
2022/10/04
3120
Vue.js 中 nextTick | 笔记
引言 对 Vue 组件数据(props 或状态)的更改不会立即反映在 DOM 中。 相反,Vue 异步更新 DOM。 你可以使用 Vue.nextTick() 或 vm.$nextTick() 函数捕获 Vue 更新 DOM 的时刻。 让我们详细了解这些函数的工作原理。 nextTick() 当 Vue 组件数据发生变化时,DOM 会异步更新。 Vue 会收集来自所有组件的多个虚拟 DOM 更新,然后创建一个批处理来更新DOM。 在单个批次中更新 DOM 比进行多个小的更新更高效。 例如,让我们考虑一个切换元素显示的组件:
yiyun
2023/09/30
2820
Vue.js 中 nextTick | 笔记
第八章:vue生命周期、vue的DOM操作、mixin混入,插件
开发过程中当多个组件开发时有相同类名时,此时vue会按照组件的导入顺序进行解析,后导入的组件 会覆盖先导入的组件类名样式
用户9184480
2024/12/13
1230
重磅来袭~~~ Vue原来可以这样写,开发效率杠杠的
每天上班写着重复的代码,当一个cv仔,忙到八九点,工作效率低,感觉自己没有任何提升。如何能更快的完成手头的工作,提高自己的开发效率,在上一篇《绝对干货~!学会这些Vue小技巧,可以早点下班和女神约会了》,小编整理了一些Vue开发技巧,今天小编又整理了一些新的Vue使用技巧。你们先加班,我先下班陪女神去逛街了。
前端进击者
2021/07/27
5190
Vue 开发技巧总结
v-model 是 Vue 提供的一个语法糖,它本质上是由 value 属性 + input 事件组成的(都是原生的默认属性)
Krry
2020/08/28
6170
3.vue生命周期钩子函数有哪些?(vue生命周期的理解)
1、beforeCreate(创建前):beforeCreate钩子函数,这个时候,vue实例的挂载元素$el和数据对象data都为undefined,还未初始化。无法访问到数据和真实的dom和data中的数据,可以在这里面使用loading
全栈程序员站长
2022/07/28
7990
3.vue生命周期钩子函数有哪些?(vue生命周期的理解)
Vue JSX、自定义 v-model
最初用到 JSX,就是做这个博客的时候。iview 表格组件,不支持像 element 那样直接写 html 代码渲染,只能通过 render 函数渲染,也就是 JSX 语法
Krry
2020/07/16
4.7K1
相关推荐
Vue.nextTick 的原理和用途
更多 >
领券
社区富文本编辑器全新改版!诚邀体验~
全新交互,全新视觉,新增快捷键、悬浮工具栏、高亮块等功能并同时优化现有功能,全面提升创作效率和体验
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档
查看详情【社区公告】 技术创作特训营有奖征文