透析Vue的nextTick原理

nextTick 是 Vue.js 中的一个核心机制,用于在 下一次 DOM 更新周期后 执行回调函数。它的核心原理是 利用 JavaScript 的事件循环机制(Event Loop),结合微任务(Microtask)或宏任务(Macrotask)的调度策略,确保回调在 DOM 更新完成后执行。


核心原理分析

1. DOM 更新的异步性

Vue 的数据驱动视图更新是 异步批量执行 的。当数据变化时,Vue 不会立即更新 DOM,而是开启一个队列,缓冲同一事件循环中的所有数据变更。这样可以避免不必要的重复渲染,提高性能。

2. 回调队列
  • 每次调用 nextTick(callback),Vue 会将 callback 推入一个 回调队列

  • 当需要执行队列时,Vue 会通过 异步任务调度器 触发队列中所有回调的执行。

3. 异步任务优先级

Vue 会优先使用 微任务(Microtask) 实现异步调度(因为微任务会在当前事件循环的末尾执行),但在不支持微任务的环境下会降级为 宏任务(Macrotask)。具体实现策略如下:

  • 现代浏览器:优先使用 Promise.then()(微任务)。

  • 不支持 Promise 的环境:降级到 MutationObserver(微任务)。

  • 其他环境(如旧版 IE):使用 setImmediate 或 setTimeout(fn, 0)(宏任务)。


源码简化逻辑

以下是 Vue 内部 nextTick 的简化实现逻辑:

const callbacks = []; // 回调队列
let pending = false; // 标记是否已向任务队列添加任务function flushCallbacks() {pending = false;const copies = callbacks.slice(0);callbacks.length = 0; // 清空队列for (let i = 0; i < copies.length; i++) {copies[i](); // 依次执行回调}
}function nextTick(callback) {callbacks.push(() => {if (callback) {try {callback();} catch (e) {handleError(e);}}});if (!pending) {pending = true;// 根据环境选择异步策略if (typeof Promise !== 'undefined') {Promise.resolve().then(flushCallbacks);} else if (typeof MutationObserver !== 'undefined') {// 使用 MutationObserver 模拟微任务const observer = new MutationObserver(flushCallbacks);const textNode = document.createTextNode(String(counter));observer.observe(textNode, { characterData: true });textNode.data = String((counter + 1) % 2);} else {setTimeout(flushCallbacks, 0);}}
}

关键点总结

  1. 异步批量更新
    Vue 会将同一事件循环中的多个数据变更合并,避免频繁的 DOM 操作。

  2. 微任务优先
    优先使用 Promise.then() 或 MutationObserver 触发回调,确保回调在 当前事件循环的末尾(DOM 更新后)执行。

  3. 降级策略
    根据浏览器特性选择合适的异步 API,确保兼容性。

  4. 回调队列
    所有通过 nextTick 注册的回调会被推入队列,统一在下一个事件循环中执行。


使用场景

// 修改数据后,立即获取更新后的 DOM
this.message = 'Updated';
this.$nextTick(() => {console.log(this.$el.textContent); // 输出 'Updated'
});

总结

nextTick 的核心是通过 异步任务队列 和 事件循环机制,确保回调在 DOM 更新完成后执行。这种设计既优化了性能(减少重复渲染),又保证了开发者能在正确时机获取最新的 DOM 状态。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/898579.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

WRF/Chem 模式技术解读:为大气污染治理提供有力支撑

技术点目录 第一部分、WRF-Chem模式应用案例和理论基础第二部分、Linux环境配置及WRF-CHEM第三部分、WRF-Chem模式编译&#xff0c;排放源制作第四部分、WRF-Chem数据准备&#xff08;气象、排放、初边界条件等&#xff09;&#xff0c;案例实践第五部分、模拟结果提取、数据可…

ccfcsp2701如此编码

//如此编码 #include<iostream> using namespace std; int main(){int n,m;cin>>n>>m;int a[21],b[21],c[21];for(int i1;i<n;i){cin>>a[i];}c[0]1;for(int i1;i<n;i){c[i]c[i-1]*a[i];}b[1](m%c[1])/c[0];int s1,s20;for(int i2;i<n;i){s2s2…

74HC04(反相器)和74HC14(反相器、施密特触发器)的区别

74HC04和74HC14的具体区别详解 同样具有反相器功能&#xff0c;你知道74HC04和74HC14的具体区别吗&#xff1f; 74HC04 对于74HC04很好理解&#xff0c;输入低电平&#xff0c;输出高电平&#xff1b;输入高电平&#xff0c;输出低电平。 建议操作条件&#xff1a; 下图是TI的…

如何缓解大语言模型推理中的“幻觉”(Hallucination)?

目录 如何缓解大语言模型推理中的“幻觉”&#xff08;Hallucination&#xff09;&#xff1f; 1. 什么是大语言模型的“幻觉”&#xff08;Hallucination&#xff09;&#xff1f; 幻觉的常见类型 2. 如何缓解大模型的幻觉问题&#xff1f; 方法 1&#xff1a;使用知识检索…

Linux权限管理详解

Linux权限管理系统 Linux作为一个多用户操作系统&#xff0c;其权限管理系统是保障系统安全的重要组成部分。通过合理设置文件和目录的权限&#xff0c;可以有效控制用户对系统资源的访问。 一、基本权限概念 Linux系统中的权限分为三类&#xff1a; 读权限(r)&#xff1a;…

第十四次CCF-CSP认证(含C++源码)

第十四次CCF-CSP认证 卖菜满分思路 买菜满分思路 再卖菜满分题解&#xff08;差分约束&#xff09;solution 1(枚举 correct but 超时)solution 2(正解) 卖菜 题目链接 满分思路 就是模拟一下这个调整第二天菜价的过程&#xff0c;其中对于两种只有一个邻居的情况下做出调整&…

CCBCISCN复盘

AWDP – ccfrum 自己搭了一下环境, 复现一下这道题目, 之前比赛的时候完全没想到这个漏洞要怎么打, 修也不知道要怎么修, 就仅仅是对用户名的账号和密码进行了一下过滤, 完全没起到作用, 唉, 实在太菜 如果想要尝试复现的话可以尝试拉取这个镜像, 我打完之后就直接把这个容器给…

(每日一道算法题)交易逆序对的总数

LCR 170. 交易逆序对的总数 - 力扣&#xff08;LeetCode&#xff09; 在股票交易中&#xff0c;如果前一天的股价高于后一天的股价&#xff0c;则可以认为存在一个「交易逆序对」。请设计一个程序&#xff0c;输入一段时间内的股票交易记录 record&#xff0c;返回其中存在的「…

【操作系统】共享数据的竞争问题

共享数据的竞争问题 问题&#xff1a;保护中断与主程序共享的avg_data方法一&#xff1a;使用关中断保护1. 添加关中断宏2. 修改数据读取代码3. 修改中断服务程序&#xff08;ISR&#xff09; 方法二&#xff1a;使用原子操作&#xff08;需平台支持&#xff09;1. 定义原子类型…

VS010生成可由MATLAB2016调用的DLL文件方法

亲测实用&#xff0c;不用配置杂七杂八的依赖项 1&#xff1a;新建Win32的DLL输出项目 2&#xff1a;修改为release模式 3&#xff1a;添加calc.cpp文件&#xff0c;即要导出的函数myadd&#xff1a; #include "calc.h" __declspec(dllexport) int myadd(int a,in…

机器学习Pandas_learn4

import pandas as pddef calculate_goods_covariance():# 定义商品销售数据字典goods_sales_data {"时期": ["一期", "二期", "三期", "四期"],"苹果": [15, 16, 3, 2],"橘子": [12, 14, 16, 18],&quo…

优选算法系列(3.二分查找 )

目录 一.二分查找&#xff08;easy&#xff09; 题目链接&#xff1a;704. 二分查找 - 力扣&#xff08;LeetCode&#xff09; 解法&#xff1a; 代码&#xff1a; 二.在排序数组中查找元素的第⼀个和最后⼀个位置&#xff08;medium&#xff09; 题目链接&#xff1a;34.…

DAY36贪心算法Ⅴ

56. 合并区间 - 力扣&#xff08;LeetCode&#xff09; class Solution { static bool cmp(vector<int>&a,vector<int>&b){return a[0] < b[0]; } public:vector<vector<int>> merge(vector<vector<int>>& intervals) {so…

阿里云服务器部署 五 Nginx + springboot

Nginx的部分配置 1. 基础容灾配置&#xff08;被动健康检查&#xff09; 在 upstream 块中&#xff0c;通过 max_fails 和 fail_timeout 参数定义故障转移规则&#xff1a; 在 upstream 块中&#xff0c;通过 max_fails 和 fail_timeout 参数定义故障转移规则&#xff1a;…

基于大模型的下颌前突畸形预测及治疗方案研究报告

目录 一、引言 1.1 研究背景 1.2 研究目的 1.3 研究意义 二、大模型技术原理与应用现状 2.1 大模型的基本原理 2.2 在医疗领域的应用案例 2.3 在下颌前突畸形研究中的可行性分析 三、下颌前突畸形概述 3.1 定义与分类 3.2 流行病学特征 3.3 病因与发病机制 3.4 对…

接口自动化测试框架详解

&#x1f345; 点击文末小卡片&#xff0c;免费获取软件测试全套资料&#xff0c;资料在手&#xff0c;涨薪更快 接口自动化测试是指通过编写程序来模拟用户的行为&#xff0c;对接口进行自动化测试。Python是一种流行的编程语言&#xff0c;它在接口自动化测试中得到了广泛…

Day11 动态规划入门

动态规划 就是 : 给定一个问题&#xff0c;我们把它拆成一个个子问题&#xff0c;直到子问题可以直接解决。然后把子问题的答案保存起来&#xff0c;以减少重复计算。再根据子问题答案反推&#xff0c;得出原问题解的一种方法. 记忆化搜索 暴力dfs 记录答案 动态规划入门思…

[AI速读]用持续集成(CI)优化芯片验证环境:Jenkins与EDA工具的实战指南

在芯片验证中,回归测试(Regression Test)是确保设计稳定性的关键步骤。但随着设计复杂度增加,手动管理海量测试用例、分析日志和覆盖率数据变得异常耗时。本文将介绍如何利用持续集成(CI)工具Jenkins,结合EDA验证环境(如Cadence vManager),实现自动化测试与结果分析,…

深度解析:JavaScript变量声明的演变与核心差异(var/let/隐式声明)

深度解析&#xff1a;JavaScript变量声明的演变与核心差异&#xff08;var/let/隐式声明&#xff09; 一、JavaScript变量声明的演进史 JavaScript的变量声明机制经历了三个阶段演进&#xff1a; 原始阶段&#xff08;ES5及之前&#xff09;&#xff1a;仅 var 声明 隐式全局…

第2.1节:AWK脚本结构

1 第2.1节&#xff1a;AWK脚本结构 1.1 第1个awk脚本 假设有如下的数据待处理&#xff0c;需要将第2列提取出来&#xff1a; #, 名称, 大小, 类型, 修改, 属性 1, COMMIT_EDITMSG, 331 bytes, 文件, 24/09/16 08:42:19, -a----- 2, config, …