React 其他 Hooks

其他 Hooks

useRef

可用于获取 DOM 元素

javascript 复制代码
 const ScrollRef = useRef(null)
 ScrollRef.current

useContext

(先回顾一下之前的 Context 知识,借用之前 ppt 和源码)

Hooks 中使用 useContext获取 context 的值

javascript 复制代码
 // 父组件创建 context
 export const MenuContext = createContext<IMenuContext>({ index: 0 })    // 初始值
 ​
 // context 传递的数据
 const passedContext: IMenuContext = {
     index: currentActive ? currentActive : 0,
     onSelect: handleClick,
 }
 ​
 <MenuContext.Provider value={passedContext}>
     {renderChildren()}
 </MenuContext.Provider>
 ​
 // 子组件使用
 const context = useContext(MenuContext)
 context.onSelect(index)

useReducer

useReducer 和 redux 不同

  • useReducer 是 useState 的代替方案,用于更复杂的 state 变化逻辑

  • useReducer 是单组件的状态管理,多组件通讯还是需要 props 传递数据

  • redux 是全局的状态管理,多组件可共享数据

useMemo

(先回顾一下之前的性能优化部分的知识,借用之前 ppt 和源码)

  • React 默认更新所有子组件

  • Class 组件使用 SCU 或者 PureComponent 进行优化

  • Hooks 里使用 useMemo 缓存数据(和 PureComponent 原理是一样的)

javascript 复制代码
 // 子组件使用 memo()包裹  (对props浅层对比)
 const Child = memo(({ userInfo }) => {
     console.log('Child render ...', userInfo)
     
     return <>
      </>
 })
 ​
 // 父组件 用 useMemo 缓存传递的数据, 有依赖
 const userInfo = useMemo(() => {
     return { name, age = 21 }
 }, [name])
 ​
 <Child userInfo={userInfo}/>

useCallback

在 useMemo 的基础上继续,如果是函数传递给子组件,怎么办?

  • useMemo 缓存数据

  • useCallback 缓存函数

javascript 复制代码
 // 子组件
 const Child = ({ onChange }) => {
     console.log('Child render ...', onChange)
     
     return <>
      </>
 }
 ​
 // 父组件 用 useCallback 缓存传递的函数, 依赖 []
 const onChange = useCallback(e => {
     console.log(e.target.value)
 }, [])
 ​
 <Child onChange={onChange}/>
相关推荐
颜酱3 分钟前
一步步实现字符串计算器:从「转整数」到「带括号与优化」
javascript·后端·算法
浪浪山_大橙子3 分钟前
OpenClaw 十分钟快速,安装与接入完全指南 - 推荐使用trae 官方 skills 安装
前端·人工智能
忆江南6 分钟前
iOS 可视化埋点与无痕埋点详解
前端
离开地球表面_998 分钟前
金三银四程序员跳槽指南:从简历到面试再到 Offer 的全流程准备
前端·后端·面试
_柳青杨10 分钟前
跨域获取 iframe 选中文本?自己写个代理中间层,再也不求后端!
前端
比尔盖茨的大脑10 分钟前
事件循环底层原理:从 V8 引擎到浏览器实现
前端·javascript·面试
天才熊猫君10 分钟前
Vue3 命令式弹窗原理和 provide/inject 隔离机制详解
前端
bluceli11 分钟前
Vue 3 Composition API深度解析:构建可复用逻辑的终极方案
前端·vue.js
程序员ys13 分钟前
前端权限控制设计
前端·vue.js·react.js
卓卓不是桌桌13 分钟前
如何优雅地处理 iframe 跨域通信?这是我的开源方案
javascript·架构