0

0

如何利用 VNode 属性 patchProps 实现事件绑定?底层渲染的交互实战

舞夢輝影

舞夢輝影

发布时间:2026-03-19 08:13:58

|

785人浏览过

|

来源于php中文网

原创

patchProps 是 Vue 3 内部用于更新 VNode 属性与事件监听器的核心函数,负责标准化事件名、动态增删监听器、分流处理原生/自定义事件,并将事件生命周期纳入虚拟 DOM 协调体系。

如何利用 vnode 属性 patchprops 实现事件绑定?底层渲染的交互实战

在 Vue 3 的底层渲染机制中,patchProps 并不是一个直接暴露给开发者的 API,而是 runtime-core 内部用于更新 VNode 属性(包括事件)的核心函数。它不负责“绑定事件”,而是根据新旧 props 差异,决定如何设置、更新或移除 DOM 元素的属性与事件监听器。要真正理解事件绑定如何通过 VNode 和 patchProps 落地,需结合响应式更新、VNode 创建、diff 策略与平台补丁逻辑来看。

事件名标准化:从 onXxx 到小写 addEventListener

Vue 模板中写的 @click="handler" 或 JSX 中的 onClick: handler,在编译后会转为 VNode 的 props 对象中的 onClick 字段。但真实 DOM 不认 onClick,只接受 click 这类小写事件名。因此 patchProps 在处理事件时,会做标准化转换:

  • 识别以 on 开头的 key(如 onClickonInput),截取后缀并转为小写(clickinput
  • 调用 add/removeEventListener,而非设置 el.onclick = fn —— 这保证了可多次绑定、支持捕获/被动等选项
  • 若值为数组(如 [fn, { once: true }]),会自动解构并传入 addEventListener 第三个参数

事件监听器的动态更新与清理

patchProps 不只是“加监听器”,更关键的是在组件更新时精准比对、复用或销毁:

  • 若旧 props 有 onClick: oldFn,新 props 改为 onClick: newFn,则先 removeEventListener('click', oldFn),再 addEventListener('click', newFn)
  • 若新 props 中该事件字段为 nullundefined,直接移除对应监听器,避免内存泄漏
  • 对于内联函数(如 @click="count++"),每次 render 都生成新函数,导致频繁移除+重绑——这是性能隐患,应尽量用方法引用或 useCallback 类思路缓存

自定义事件与原生事件的分流处理

Vue 组件的 emits 声明会影响事件是否透传到根元素。这个判断发生在 patchProps 之前,由 renderComponentRootcreateApp 的代理逻辑完成:

Felvin
Felvin

AI无代码市场,只需一个提示快速构建应用程序

下载
  • 若组件声明了 emits: ['submit'],且父级传入 onSubmit,该事件不会进入根 DOM 元素的 props,而是被内部 emit 机制消费
  • 若未声明但传了 onScroll,则视为原生事件,交由 patchProps 处理并绑定到根元素
  • 可通过 v-bind="$attrs" 显式透传所有未声明事件(配合 inheritAttrs: false

实战:手动触发 patchProps 更新事件(调试/高级场景)

虽然日常开发无需调用 patchProps,但在编写自定义渲染器、调试 diff 行为或封装底层工具时,可能需要模拟其行为:

  • 获取当前 DOM 元素和新旧 VNode:const el = vnode.el; const prevProps = vnode.patchFlag ? vnode.props : null;
  • 调用内部函数(仅限 dev 模式调试):import { patchProps } from 'vue/dist/vue.runtime.esm-bundler.js'; patchProps(el, prevProps, nextProps, isSVG, null);
  • 注意:该函数依赖完整上下文(如 renderer options、patchFlags),生产环境不应直接使用;推荐方式仍是通过响应式数据驱动 VNode 重绘

真正掌握事件绑定,不是背住 patchProps 的签名,而是看清它如何串联模板编译、响应式触发、VNode diff 与 DOM 操作这一整条链路。事件能“自动更新”,本质是 Vue 把 addEventListener 的生命周期,完全纳入了虚拟 DOM 的协调(reconciliation)体系中。

相关标签:

本站声明:本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

WorkBuddy
WorkBuddy

腾讯云推出的AI原生桌面智能体工作台

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
python是前端还是后端
python是前端还是后端

Python属于前端也属于后端,其灵活性和丰富的生态系统使得开发人员能够在不同的领域中灵活运用。本专题为大家提供python相关的文章、下载、课程内容,供大家免费下载体验。

202

2023.08.11

前端如何实现即时通讯
前端如何实现即时通讯

实现即时通讯的方法有WebSocket、Long Polling、Server-Sent Events、WebRTC等等。详细介绍:1、WebSocket,它可以在客户端和服务器之间建立持久连接,实现实时的双向通信,前端可以使用 WebSocket API来创建WebSocket连接,并通过发送和接收消息来实现即时通讯;2、Long Polling,是一种模拟实时通信的技术等等。

275

2023.10.09

前端和后端的区别
前端和后端的区别

前端关注的是用户界面的设计和交互,而后端则注重数据处理和逻辑控制。想了解更多前端后端的相关内容,可以阅读本专题下面的文章。

413

2024.03.19

php和前端的关联介绍
php和前端的关联介绍

php既可以作为前端语言,也可以作为后端语言。想了解更多php和前端的相关内容,可以阅读本专题下面的文章。

233

2024.03.22

前端外包工作内容有哪些
前端外包工作内容有哪些

前端外包工作内容包括:1. 网站和应用程序开发;2. 用户界面和交互设计;3. 用户体验优化;4. 设计和视觉开发;5. 跨浏览器兼容性;6. 性能优化;7. 维护和更新;8. 项目管理和沟通。想了解更多前端的相关内容,可以阅读本专题下面的文章。

123

2024.05.22

vue2.0和3.0区别
vue2.0和3.0区别

vue2.0和3.0区别:vue2的响应式原理是利⽤“Object.defineProperty()”对数据进⾏劫持结合发布订阅模式的⽅式来实现,vue3中使⽤了es6的proxy API对数据代理,实现对数据的监控。本专题为大家提供vue2.0和3.0区别的相关的文章、下载、课程内容,供大家免费下载体验。

162

2023.07.17

vue3的生命周期有哪些
vue3的生命周期有哪些

vue3的生命周期:1、beforecreate;2、created;3、beforemount;4、mounted;5、beforeupdate;6、updated;7、beforedestroy;8、destroyed;9、activated;10、deactivated等等。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

8765

2024.02.23

Vue3组合式API与组件开发实战
Vue3组合式API与组件开发实战

本专题讲解 Vue 3 组合式 API 的核心概念与应用技巧,深入分析响应式系统、生命周期管理、组件设计与复用策略。通过完整项目案例,指导前端开发者实现高性能、结构清晰的 Vue 应用,提升开发效率与代码可维护性。

40

2026.02.10

Python WebSocket实时通信与异步服务开发实践
Python WebSocket实时通信与异步服务开发实践

本专题聚焦 Python 在实时通信场景中的开发实践,系统讲解 WebSocket 协议原理、长连接管理、消息推送机制以及异步服务架构设计。内容包括客户端与服务端通信实现、连接稳定性优化、消息队列集成及高并发处理策略。通过完整案例,帮助开发者构建高效稳定的实时通信系统,适用于聊天应用、实时数据推送等场景。

7

2026.03.18

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号