第十章:useRef源码解析

前言

本章解锁useRef 源码,useRef 的源码还是很简单的,也是使用十分广泛的hook,而且使用场景还是很广泛的;
useRef 也会配合useImperativeHandleforwardRef 使用;
useRef并不会导致重新渲染,通常会做一些缓存相关的问题。

源码解析

js 复制代码
const ref = useRef(initialValue)

按照常规流程,调用HooksDispatcherOnMountInDEV.useRef 的方法,前置check检查方法,核心方法mountRef

调用mountWorkInProgressHook方法,

js 复制代码
const hook = {
    memoizedState: null,
    baseState: null,
    baseQueue: null,
    queue: null,
    next: null
};
fiber.memoizedState = hook;

mountRef的核心代码也很简单

js 复制代码
const ref = {current: initialValue};
hook.memoizedState = ref;

返回ref对象,源码还是很简单,因为ref是一个对象,默认是使用current对象,可以把useRef当成一个可以缓存的对象;

直接修改ref对象值,并不会导致组件重新渲染,需要通过其他的方法触发渲染。

update阶段

调用HooksDispatcherOnUpdateInDEV.useEffect 方法,调用check方法,核心方法updateRef

调用updateWorkInProgressHook 方法,将mount阶段创建的hook,copy一份,返回fiber.memoizedState ;

因为copy的时候会把上一次的值保存下来,并且是对象引用,所以每次都是最新值。

总结

useRef就是简单创建hook对象,创建一个ref对象。

补充

在使方法通常是

js 复制代码
const ref = useRef(null);
ref.current = value;

可以直接通过改变值的方式修改;

js 复制代码
const ref = useRef(null);
<div ref={ref}></div>

第二种方式涉及到react dom解析,理解成ref.current = div ;

第一种方式常常使用方式,因为ref是一个对象,也可以按照对象方式使用,

js 复制代码
const ref = useRef(null);
ref.key = 'value';
console.log(ref.key)

不常用,不推荐,但是可以使用。

相关推荐
co松柏13 分钟前
AI+Excalidraw,用自然语言画手绘风格技术图
前端·人工智能·后端
用户812748281512021 分钟前
安卓Settings值原理源码剖析存储最大的字符数量是多少?
前端
用户812748281512025 分钟前
安卓14剖析SystemUI的ShadeLogger/LogBuffer日志动态控制输出dumpsy机制
前端
Ankkaya27 分钟前
cloudflare + github 实现留言板
前端·github
是你的小橘呀28 分钟前
单页应用路由怎么搞?React Router 从原理到实战全解析!
前端·javascript
xuedaobian28 分钟前
2025年我是怎么用AI写代码的
前端·程序员·ai编程
风止何安啊29 分钟前
Set/Map+Weak三剑客的骚操作:JS 界的 “去重王者” ,“万能钥匙”和“隐形清洁工”
前端·javascript·面试
saberxyL29 分钟前
前端登录加密与Token管理实践
前端
3秒一个大33 分钟前
React 中 Context 的作用与用法:从主题切换案例说起
前端·react.js
2501_9444460040 分钟前
Flutter&OpenHarmony文本输入组件开发
前端·javascript·flutter