当前位置: 首页 > news >正文

React 其他 Hooks

其他 Hooks

useRef

可用于获取 DOM 元素

 const ScrollRef = useRef(null)ScrollRef.current

useContext

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

Hooks 中使用 useContext获取 context 的值

 // 父组件创建 contextexport 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 原理是一样的)

 // 子组件使用 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 缓存函数

 // 子组件const Child = ({ onChange }) => {console.log('Child render ...', onChange)return <></>}​// 父组件 用 useCallback 缓存传递的函数, 依赖 []const onChange = useCallback(e => {console.log(e.target.value)}, [])​<Child onChange={onChange}/>

http://www.lryc.cn/news/358452.html

相关文章:

  • echarts配置记录,一些已经废弃的写法
  • 电量计量芯片HLW8110的前端电路设计与误差分析校正.pdf 下载
  • Redis实践记录与总结
  • 持续总结中!2024年面试必问 20 道 Rocket MQ面试题(三)
  • Android 自定义Adapter关键函数getView性能最优使用
  • Linux服务上MySQL的启动、重启和关闭
  • ctfshow web入门 嵌入式 bash cpp pwn
  • 【ONE·Git || 基本用法入门】
  • 【运维项目经历|021】Spark大数据分析平台建设项目
  • 装机数台,依旧还会心念i5-12600KF的性能和性价比优势:
  • Docker-----emqx部署
  • 三数之和-力扣
  • 2024 五月份国内外CTF 散装re 部分wp
  • [猫头虎分享21天微信小程序基础入门教程]第21天:小程序的社交分享与消息推送
  • aop整理
  • Sublime Text 基础教程(个人总结)
  • 线程安全 - 笔记
  • 分支机构多,如何确保文件跨域传输安全可控?
  • 长安链使用Golang编写智能合约教程(二)
  • jpom linux发布前端 ruoyi
  • K8S认证|CKA题库+答案| 15. 备份还原Etcd
  • 软件架构设计属性之一:功能性属性浅析
  • 学习Java的日子 Day48 函数,DOM
  • Scikit-Learn朴素贝叶斯
  • 网页设计步骤总结
  • 第十三期Big Demo Day亮点项目:CCarbon重塑碳交易生态,助力全球绿色发展
  • python基础知识总结(第一节)
  • DOS学习-目录与文件应用操作经典案例-comp
  • 原神抽卡点名程序教程(直接下载用)
  • gpt-4o继续迭代考场安排程序 一键生成考场清单