ReactReconcileTransaction源码(待定)

2023-11-02 22:38

本文主要是介绍ReactReconcileTransaction源码(待定),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

ReactReconcileTransaction模块用于在组件元素挂载前后执行指定的钩子函数,特别是componentDidMount、componentDidUpdate生命周期调用方法,其次是向组件实例注入updater参数,实现setState、replaceState、forceUpdate方法。

 

'use strict';var _assign = require('object-assign');// 回调函数队列,经PooledClass工厂化,使用getPooled方法创建实例、release方法销毁实例数据,即回调函数及其上下文
var CallbackQueue = require('./CallbackQueue');// PooledClass.addPoolingTo(CopyConstructor)用于将构造函数CopyConstructor转化为工厂函数
// 意义是管理实例数据的创建和销毁,并将销毁数据的实例推入到实例池CopyConstructor.instancePool中
var PooledClass = require('./PooledClass');// ReactBrowserEventEmitter模块的isEnabled、setEnabled方法默认使用ReactEventListener模块的同名方法
var ReactBrowserEventEmitter = require('./ReactBrowserEventEmitter');// 输入框、文本框、contentEditable节点选中文案相关操作
var ReactInputSelection = require('./ReactInputSelection');var ReactInstrumentation = require('./ReactInstrumentation');// 原型继承Transaction的某构造函数的实例将拥有perform(method,args)方法
// 实现功能为,method函数执行前后,调用成对的前置钩子initialize、及后置钩子close;initialize为close提供参数
var Transaction = require('./Transaction');// 作为组件构造函数ReactComponent的第三个参数updater传入
// 组件内的setState、replaceState、forceUpdate方法都通过调用ReactUpdateQueue的相应方法实现
var ReactUpdateQueue = require('./ReactUpdateQueue');// 缓存选中文案的数据后,再行选中文案
var SELECTION_RESTORATION = {// 获取选中节点及文案的信息initialize: ReactInputSelection.getSelectionInformation,// 以initialize选中文案的信息选中相关节点及文案close: ReactInputSelection.restoreSelection
};// 组件绘制过程中截断事件派发,ReactBrowserEventEmitter.ReactEventListener._enabled置否实现
var EVENT_SUPPRESSION = {initialize: function () {var currentlyEnabled = ReactBrowserEventEmitter.isEnabled();ReactBrowserEventEmitter.setEnabled(false);return currentlyEnabled;},close: function (previouslyEnabled) {ReactBrowserEventEmitter.setEnabled(previouslyEnabled);}
};// 通过CallbackQueue回调函数队列机制,即this.reactMountReady
//    执行this.reactMountReady.enqueue(fn)注入componentDidMount、componentDidUpdate方法
// 通过Transaction添加前、后置钩子机制
//    前置钩子initialize方法用于清空回调队列;close用于触发回调函数componentDidMount、componentDidUpdate执行
var ON_DOM_READY_QUEUEING = {initialize: function () {this.reactMountReady.reset();},close: function () {this.reactMountReady.notifyAll();}
};var TRANSACTION_WRAPPERS = [SELECTION_RESTORATION, EVENT_SUPPRESSION, ON_DOM_READY_QUEUEING];// 开发环境调试相关
if (process.env.NODE_ENV !== 'production') {TRANSACTION_WRAPPERS.push({initialize: ReactInstrumentation.debugTool.onBeginFlush,close: ReactInstrumentation.debugTool.onEndFlush});
}// 参数useCreateElement决定创建dom节点的时候是使用document.createElement方法,还是拼接字符串
function ReactReconcileTransaction(useCreateElement) {this.reinitializeTransaction();// 通过Transaction模块清空前后钩子// 浏览器端渲染使用,虽然浏览器端渲染使用ReactServerRenderingTransaction// 客户端渲染设置此值为否,是ReactDOMComponent、ReactDOMTextComponent模块执行mountComponent的需要this.renderToStaticMarkup = false;// 用于挂载回调函数,如componentDidMount、componentDidUpdate等// 通过Transcation机制,作为后置钩子执行this.reactMountReady = CallbackQueue.getPooled(null);this.useCreateElement = useCreateElement;
}var Mixin = {// 通过Transaction模块设定前置及后置钩子,[{initialize,close}]形式getTransactionWrappers: function () {return TRANSACTION_WRAPPERS;},// 获取this.reactMountReady,用于添加回调函数如getReactMountReady().enqueue(fn)getReactMountReady: function () {return this.reactMountReady;},// 作为组件构造函数ReactComponent的第三个参数updater传入// 组件内的setState、replaceState、forceUpdate方法都通过调用ReactUpdateQueue的相应方法实现getUpdateQueue: function () {return ReactUpdateQueue;},// 获取this.reactMountReady中添加的回调函数componentDidMount、componentDidUpdate的个数checkpoint: function () {return this.reactMountReady.checkpoint();},// 将this.reactMountReady中添加的回调函数个数设为checkpointrollback: function (checkpoint) {this.reactMountReady.rollback(checkpoint);},// 清空this.reactMountReady中的回调函数componentDidMount、componentDidUpdate,再销毁this.reactMountReadydestructor: function () {CallbackQueue.release(this.reactMountReady);this.reactMountReady = null;}
};// 通过原型方法赋值获得Transaction中的reinitializeTransaction、getTransactionWrappers、perform方法
// reinitializeTransaction方法,用于重置钩子函数
// getTransactionWrappers方法,用于添加钩子函数,[{initialize,close}]形式
// perform(method)执行前后钩子函数、及method函数
//    method函数为ReactMount模块中的mountComponentIntoNode函数
_assign(ReactReconcileTransaction.prototype, Transaction, Mixin);// 通过PooledClass模块管理实例的创建ReactReconcileTransaction.getPooled
//    及实例数据的销毁ReactReconcileTransaction.release 
PooledClass.addPoolingTo(ReactReconcileTransaction);// 通过ReactUpdates模块输出接口ReactUpdates.ReactReconcileTransaction
// 实现功能为在mountComponentIntoNode函数调用指定的钩子函数,包括用户配置的componentDidMount、componentDidUpdate回调
// 使用方式为getPooled方法创建实例,release方法销毁实例数据
// perform方法执行mountComponentIntoNode函数,及前后钩子函数
// getReactMountReady().enqueue(fn)添加用户配置的componentDidMount、componentDidUpdate回调
// getReactMountReady().checkpoint()方法获取回调个数
// getReactMountReady().rollback(checkpoint)将回调个数设为checkpoint
// 另一实现功能为向组件实例注入updater参数,将向setState、replaceState、forceUpdate方法提供函数功能
module.exports = ReactReconcileTransaction;

 

这篇关于ReactReconcileTransaction源码(待定)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/333765

相关文章

Go中sync.Once源码的深度讲解

《Go中sync.Once源码的深度讲解》sync.Once是Go语言标准库中的一个同步原语,用于确保某个操作只执行一次,本文将从源码出发为大家详细介绍一下sync.Once的具体使用,x希望对大家有... 目录概念简单示例源码解读总结概念sync.Once是Go语言标准库中的一个同步原语,用于确保某个操

Java汇编源码如何查看环境搭建

《Java汇编源码如何查看环境搭建》:本文主要介绍如何在IntelliJIDEA开发环境中搭建字节码和汇编环境,以便更好地进行代码调优和JVM学习,首先,介绍了如何配置IntelliJIDEA以方... 目录一、简介二、在IDEA开发环境中搭建汇编环境2.1 在IDEA中搭建字节码查看环境2.1.1 搭建步

JAVA智听未来一站式有声阅读平台听书系统小程序源码

智听未来,一站式有声阅读平台听书系统 🌟 开篇:遇见未来,从“智听”开始 在这个快节奏的时代,你是否渴望在忙碌的间隙,找到一片属于自己的宁静角落?是否梦想着能随时随地,沉浸在知识的海洋,或是故事的奇幻世界里?今天,就让我带你一起探索“智听未来”——这一站式有声阅读平台听书系统,它正悄悄改变着我们的阅读方式,让未来触手可及! 📚 第一站:海量资源,应有尽有 走进“智听

Java ArrayList扩容机制 (源码解读)

结论:初始长度为10,若所需长度小于1.5倍原长度,则按照1.5倍扩容。若不够用则按照所需长度扩容。 一. 明确类内部重要变量含义         1:数组默认长度         2:这是一个共享的空数组实例,用于明确创建长度为0时的ArrayList ,比如通过 new ArrayList<>(0),ArrayList 内部的数组 elementData 会指向这个 EMPTY_EL

如何在Visual Studio中调试.NET源码

今天偶然在看别人代码时,发现在他的代码里使用了Any判断List<T>是否为空。 我一般的做法是先判断是否为null,再判断Count。 看了一下Count的源码如下: 1 [__DynamicallyInvokable]2 public int Count3 {4 [__DynamicallyInvokable]5 get

工厂ERP管理系统实现源码(JAVA)

工厂进销存管理系统是一个集采购管理、仓库管理、生产管理和销售管理于一体的综合解决方案。该系统旨在帮助企业优化流程、提高效率、降低成本,并实时掌握各环节的运营状况。 在采购管理方面,系统能够处理采购订单、供应商管理和采购入库等流程,确保采购过程的透明和高效。仓库管理方面,实现库存的精准管理,包括入库、出库、盘点等操作,确保库存数据的准确性和实时性。 生产管理模块则涵盖了生产计划制定、物料需求计划、

Spring 源码解读:自定义实现Bean定义的注册与解析

引言 在Spring框架中,Bean的注册与解析是整个依赖注入流程的核心步骤。通过Bean定义,Spring容器知道如何创建、配置和管理每个Bean实例。本篇文章将通过实现一个简化版的Bean定义注册与解析机制,帮助你理解Spring框架背后的设计逻辑。我们还将对比Spring中的BeanDefinition和BeanDefinitionRegistry,以全面掌握Bean注册和解析的核心原理。

音视频入门基础:WAV专题(10)——FFmpeg源码中计算WAV音频文件每个packet的pts、dts的实现

一、引言 从文章《音视频入门基础:WAV专题(6)——通过FFprobe显示WAV音频文件每个数据包的信息》中我们可以知道,通过FFprobe命令可以打印WAV音频文件每个packet(也称为数据包或多媒体包)的信息,这些信息包含该packet的pts、dts: 打印出来的“pts”实际是AVPacket结构体中的成员变量pts,是以AVStream->time_base为单位的显

kubelet组件的启动流程源码分析

概述 摘要: 本文将总结kubelet的作用以及原理,在有一定基础认识的前提下,通过阅读kubelet源码,对kubelet组件的启动流程进行分析。 正文 kubelet的作用 这里对kubelet的作用做一个简单总结。 节点管理 节点的注册 节点状态更新 容器管理(pod生命周期管理) 监听apiserver的容器事件 容器的创建、删除(CRI) 容器的网络的创建与删除

red5-server源码

red5-server源码:https://github.com/Red5/red5-server