返回顶部
首页 > 资讯 > 精选 >vue是异步渲染的原因有哪些
  • 717
分享到

vue是异步渲染的原因有哪些

2023-07-04 20:07:31 717人浏览 薄情痞子
摘要

这篇文章主要介绍了Vue是异步渲染的原因有哪些的相关知识,内容详细易懂,操作简单快捷,具有一定借鉴价值,相信大家阅读完这篇vue是异步渲染的原因有哪些文章都会有所收获,下面我们一起来看看吧。原因:可以提升性能。如果不采用异步更新,那么每次更

这篇文章主要介绍了Vue是异步渲染的原因有哪些的相关知识,内容详细易懂,操作简单快捷,具有一定借鉴价值,相信大家阅读完这篇vue是异步渲染的原因有哪些文章都会有所收获,下面我们一起来看看吧。

原因:可以提升性能。如果不采用异步更新,那么每次更新数据都会对当前组件进行重新渲染;所以为了性能考虑,Vue会在本轮数据更新后,再去异步更新视图,而不是每当有数据更新,就立即更新视图。

1、nextTick()的原理及作用

nextTick确保我们所操作的DOM是更新之后的。

(1)应用场景在视图更新之后,基于新的视图进行操作。

  • 在数据变化后执行的某个操作,而这个操作需要使用随数据变化而变化的DOM结构的时候,这个操作就需要放在nextTick()的回调函数中。

  • 如果在created()钩子进行DOM操作,created()中dom还没有渲染,一定要放在nextTick()的回调函数中。

  • Vue采用了数据驱动视图的思想,但是在一些情况下,仍然需要操作DOM。有时候,DOM1的数据发生了变化,而DOM2需要从DOM1中获取数据,那这时就会发现DOM2的视图并没有更新,这时就需要用到了nextTick了。

(2)原理:

  • nextTick 的核心是利用了如 Promise 、MutationObserver、setImmediate、setTimeout的原生 js 方法来模拟对应的微/宏任务的实现;

  • 本质是为了利用 JS的这些异步回调任务队列实现 Vue 框架中自己的异步回调队列;

  • 本质是对JS执行原理事件循环的一种应用

nextTick 是典型的将底层JS执行原理应用到具体案例中的示例,引入异步更新队列机制的原因∶

如果不采用异步更新,那么每次更新数据都会对当前组件进行重新渲染。所以为了性能考虑,Vue 会在本轮数据更新后,再去异步更新视图。而不是每当有数据更新,就立即更新视图。

  • 为了在数据更新操作之后操作DOM,我们可以在数据变化之后立即使用nextTick(callback)

  • nextTick()将回调延迟到下一个事件循环开始时执行, 这样回调函数会在DOM更新完成后被调用,就可以拿到最新的DOM元素了。

当你设置 vm.someData = 'new value',DOM 并不会马上更新,而是在异步队列被清除,也就是下一个事件循环开始时执行更新才会进行必要的DOM更新。

(3) vue的降级策略

Vue 在内部对异步队列尝试使用原生的 Promise.then、MutationObserver setImmediate,如果执行环境不支持,则会采用 setTimeout(fn, 0) 代替,进行降级处理。降级处理的目的都是将flushCallbacks函数放入微任务或者宏任务队列,等待下一次事件循环时来执行

实际刷新队列是有可能在本次事件循环的微任务中刷新的,也可能是在下一个事件循环中刷新的。这取决于代码当前执行的环境,如若当前执行环境支持promise,那么nextTick内部实际会用Promise去执行,那么队列刷新就会在本次事件循环的微任务中去执行。

优先选择微任务的原因:微任务中更新队列是会比在宏任务中更新少一次UI渲染的

2、为何Vue采用异步渲染

vue是组件级更新组件内有数据变化时,该组件就会更新。例:this.a = 1、this.b=2(同一个watcher)

(1)原因:如果不采用异步更新,那么每次更新数据都会对当前组件进行重新渲染。所以为了性能考虑,Vue 会在本轮数据更新后,再去异步更新视图。而不是每当有数据更新,就立即更新视图。

(2)过程:

  • Vue是异步执行dom更新的,一旦观察到数据变化,Vue就会开启一个队列,然后把在同一个事件循环 (event loop) 中 观察到数据变化的 watcher 推送进这个队列。

  • 如果这个watcher被触发多次,只会被推送到队列一次。这种缓冲行为可以有效的去掉重复数据,避免不必要的计算和Dom操作。

  • 而在下一个事件循环时,Vue会清空队列,并进行必要的DOM更新。

3)源码解析:

  • 数据变化时,通过notify通知watcher进行更新操作;

  • 通过subs[i].update依次调用watcher的update(未更新视图);

  • 将watcher放到队列中,在queueWatcher会根据watcher的id进行去重(多个属性依赖一个watcher),如果队列中没有该watcher就会将该watcher添加到队列中(未更新视图);

  • 通过nextTick异步执行flushSchedulerQueue方法刷新watcher队列(更新视图);

vue是异步渲染的原因有哪些

关于“vue是异步渲染的原因有哪些”这篇文章的内容就介绍到这里,感谢各位的阅读!相信大家对“vue是异步渲染的原因有哪些”知识都有一定的了解,大家如果还想学习更多知识,欢迎关注编程网精选频道。

--结束END--

本文标题: vue是异步渲染的原因有哪些

本文链接: https://lsjlt.com/news/347320.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

猜你喜欢
  • vue是异步渲染的原因有哪些
    这篇文章主要介绍了vue是异步渲染的原因有哪些的相关知识,内容详细易懂,操作简单快捷,具有一定借鉴价值,相信大家阅读完这篇vue是异步渲染的原因有哪些文章都会有所收获,下面我们一起来看看吧。原因:可以提升性能。如果不采用异步更新,那么每次更...
    99+
    2023-07-04
  • vue页面渲染是异步的吗
    这篇文章主要介绍“vue页面渲染是异步的吗”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“vue页面渲染是异步的吗”文章能帮助大家解决问题。vue页面渲染是异步的。vue采用的是异步渲染,这样可以提升...
    99+
    2023-07-04
  • vue为什么是异步渲染
    本教程操作环境:windows7系统、vue3版,DELL G3电脑。1、nextTick()的原理及作用nextTick确保我们所操作的DOM是更新之后的。(1)应用场景:在视图更新之后,基于新的视图进行操作。在数据变化后执行的某个操作,...
    99+
    2023-05-14
    Vue 异步渲染
  • vue页面渲染是同步还是异步
    本教程操作环境:windows7系统、vue3版,DELL G3电脑。vue页面渲染是异步的。Vue在更新DOM时是异步执行的,只要侦听到数据变化,Vue将开启一个队列,并缓冲在同一事件循环中发生的所有数据变更,如果同一个watcher被多...
    99+
    2023-05-14
    异步渲染 渲染 Vue
  • vue渲染方法有哪些
    今天小编给大家分享一下vue渲染方法有哪些的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章后有所收获,下面我们一起来了解一下吧。方法是:1、用原有模板语法,挂载渲染...
    99+
    2023-06-29
  • vue使用异步组件的原因有哪些
    本篇内容主要讲解“vue使用异步组件的原因有哪些”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“vue使用异步组件的原因有哪些”吧!使用异步组件的原因:1、异步组件可以减少打包的结果,会将异步组件...
    99+
    2023-07-04
  • Vue的列表渲染方法有哪些
    本篇内容介绍了“Vue的列表渲染方法有哪些”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!1. v-for:遍历数组内容(常用)in 也可以用...
    99+
    2023-06-25
  • vue条件渲染指令有哪些
    这篇文章主要介绍“vue条件渲染指令有哪些”,在日常操作中,相信很多人在vue条件渲染指令有哪些问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”vue条件渲染指令有哪些”的疑惑有所帮助!接下来,请跟着小编一起来...
    99+
    2023-07-04
  • vue服务端渲染和客户端渲染的区别有哪些
    本文小编为大家详细介绍“vue服务端渲染和客户端渲染的区别有哪些”,内容详细,步骤清晰,细节处理妥当,希望这篇“vue服务端渲染和客户端渲染的区别有哪些”文章能帮助大家解决疑惑,下面跟着小编的思路慢慢深入,...
    99+
    2024-04-02
  • Vue渲染失败的原因是什么及如何解决
    本篇内容介绍了“Vue渲染失败的原因是什么及如何解决”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!Vue渲染失败原因及解决在进行数据双向绑定...
    99+
    2023-06-30
  • vue异步数据对页面渲染的影响
    这篇文章主要介绍“vue异步数据对页面渲染的影响”,在日常操作中,相信很多人在vue异步数据对页面渲染的影响问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”vue异步数据对页面...
    99+
    2024-04-02
  • Vue的异步渲染axios问题怎么解决
    本文小编为大家详细介绍“Vue的异步渲染axios问题怎么解决”,内容详细,步骤清晰,细节处理妥当,希望这篇“Vue的异步渲染axios问题怎么解决”文章能帮助大家解决疑惑,下面跟着小编的思路慢慢深入,一起来学习新知识吧。Vue异步渲染ax...
    99+
    2023-07-05
  • 使用vue进行渲染的过程有哪些
    使用vue进行渲染的过程有哪些?相信很多没有经验的人对此束手无策,为此本文总结了问题出现的原因和解决方法,通过这篇文章希望你能解决这个问题。为什么要使用VueVue是一款友好的、多用途且高性能的JavaScript框架,使用vue可以创建可...
    99+
    2023-06-14
  • Vue渲染失败的几种原因及解决方案
    目录Vue渲染失败原因及解决一.假设template中二.因为Vue无法检测到属性的添加和移除三. 对于数组Vue渲染错误问题Vue 报错原因解决Vue渲染失败原因及解决 在进行数据...
    99+
    2024-04-02
  • Vue.js条件渲染、列表渲染及Vue中key值的内部原理是什么
    这篇文章主要介绍“Vue.js条件渲染、列表渲染及Vue中key值的内部原理是什么”,在日常操作中,相信很多人在Vue.js条件渲染、列表渲染及Vue中key值的内部原理是什么问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希...
    99+
    2023-07-06
  • Java oom异常的原因有哪些
    Java中的OOM(OutOfMemoryError)异常是由于JVM(Java虚拟机)内存不足引起的。以下是导致OOM异常的常见原...
    99+
    2024-02-29
    Java
  • echarts无法渲染的原因及解决方法是什么
    常见的echarts无法渲染的原因及解决方法如下:原因:1. 引入echarts的路径不正确:可能是路径写错或者文件未正确引入。2....
    99+
    2023-10-08
    echarts
  • layui进度条无法渲染出来的原因是什么
    这篇文章给大家分享的是有关layui进度条无法渲染出来的原因是什么的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。前言:layui进度条渲染分为两种情况,分别是:静态渲染和动态渲染。 <div&nb...
    99+
    2023-06-08
  • java异常引发的原因有哪些
    Java异常引发的原因主要有以下几种: 代码错误:程序中存在语法错误、逻辑错误或者算法错误,导致程序无法正常执行,从而引发异常。...
    99+
    2023-10-20
    java
  • 影响CSS渲染速度的写法有哪些
    今天小编给大家分享一下影响CSS渲染速度的写法有哪些的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章后有所收获,下面我们一起来了解...
    99+
    2024-04-02
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作