第十章: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)

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

相关推荐
kyriewen6 小时前
Anthropic 估值逼近万亿美元,Claude Sonnet 5 + Claude Science 一天两连发
前端·ai编程·claude
小徐_23338 小时前
Wot UI 2.2.0 发布:Button 新增 subtle,VideoPreview 预览体验继续增强
前端·微信小程序·uni-app
天蓝色的鱼鱼10 小时前
关于 CSS 你可能不知道的属性,但关键时刻很有用
前端·css
泯泷11 小时前
第 2 篇:设计第一套字节码:Opcode、Instruction 与 Constant Pool
前端·javascript·安全
妙码生花11 小时前
从 PHP 到 AI + Golang,程序员自救转型手记(十五):优化细节、网络请求封装
前端·后端·ai编程
泯泷11 小时前
第 1 篇:从 1 + 2 开始:亲手写出第一台 JSVM
前端·javascript·安全
团团崽_七分甜11 小时前
Spring Boot 核心知识点总结
前端
lichenyang45311 小时前
从一个按钮开始,理解 ASCF 框架到底在做什么
前端
古夕12 小时前
第三方 SSO 接入实践:redirect_uri 编码、回调一致性与跨项目联调
前端·vue.js