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

react hooks

1 useEffect(setup,dependencies)

使用object.is来比较每个依赖项和它先前的值

依赖项为空数组的effect不会在组件任何props和state发生改变时重新运行

当useEffect依赖于外部传入props对象时,容易造成死循环
需要对依赖对象进行深比较

import { isEqual } from 'lodash'
const useCompare = (value: any, compare: any) => {const ref = useRef(null)if(!compare(value,ref.current)){ref.current = value}return ref.current
}const params = useCompare({...accessParam,...reqParam,
},isEqual)useEffect(()=>{
},[params])

2 useRef

应用一个不需要渲染的值,改变ref不会触发重新渲染

const ref = useRef(value)

不要在渲染期间写入或读取ref.current

通过ref操作DOM:

const ref = useRef(null)
<input ref={ref} />

获取子元素的ref

const children = forwardRef((props,ref)=>{return (<Input ref={ref}/>)
})

3 useContext

跨层级传递变量

const ThemeContext = createContext(null)<ThemeContext.Provider value='dark'><Form>
<ThemeContext.Provider/>//使用context
const context = useContext(ThemeContext)

通过context更新对象

	<Provider value={{user,setUser}}></Provider>

4 useImperativeHandle(ref,createHandle,dependencies)

用于定义ref暴露出的句柄

5 useReducer(reducer, initialArg,init?)

允许向组件里面添加一个reducer用于状态管理

  • reducer(state,action) => newState 用于更新state的纯函数
  • initialArg:初始化state的值
  • init:用于计算初始值的函数

返回值为数组:[currentState, dispatch]

注意:dispatch函数为下一次渲染更新state,因此调用后拿不到更新后的值。如果提供state与当前state一致react会跳过组件和子组件的重新渲染

用法:

//state是只读的,不可尝试修改
const reducer = (state,action) => {if(action.type === '') {return {...state}}
}const [state, dispatch] = useReducer(reducer, { age: 42 })//调用更新函数
dispatch({type: ''})

6 memo

允许组件在props没有改变的情况下跳过重新渲染

如果传递给组件的props是一个对象,应使用useMemo避免父组件每次重新创建该对象
如果传递给组件的props是一个函数,应使用useCallback进行缓存

7 createPortal(children,domNode,key?)

允许将JSX作为children渲染至DOM不同部分

应用场景:当样式有overflow:hidden或z-index,需要子组件能视觉上跳出当前容器

import {createPortal} from 'react-dom'<div>{createPortal(<p />, document.body)	}
</div>
http://www.lryc.cn/news/99624.html

相关文章:

  • 一起学数据结构(1)——复杂度
  • <el-date-picker>组件选择开始时间,结束时间自动延长30min
  • eslint-webpack-plugin
  • logback中文一直是乱码,logback中文问号
  • C++之文件操作
  • CentOS 7.6安装 MongoDB 5.0.2
  • Windows下安装python3教程
  • opencv-27 阈值处理 cv2.threshold()
  • AAOS 音频焦点请求
  • 订单系统中的幂等实现
  • 三个常用查询:根据用户名 / token查询用户信息+链表分页条件查询
  • 列表、张量、向量和矩阵的关系
  • 华为数通HCIP-ISIS高级
  • CorelDraw怎么做立体字效果?CorelDraw制作漂亮的3d立体字教程
  • 大致了解Redis
  • javaweb会话技术
  • android app控制ros机器人三(android登录界面)
  • Android版本的发展4-13
  • 【2023.7.29】浅谈手办——新人入坑指南
  • 使用贝叶斯算法完成文档分类问题
  • 【Kafka】消息队列Kafka进阶
  • 学习day55
  • C++-Rust-一次性掌握两门语言
  • 汇编调用C语言定义的全局变量
  • WEB 文件包含 /伪协议
  • ComPDFKit PDF SDK库(支持Windows、Web、Android、iOS、Mac等平台)
  • 微服务契约测试框架-Pact
  • LightGlue论文翻译
  • iOS开发-CAShapeLayer与UIBezierPath实现微信首页的下拉菜单效果
  • 《Elasticsearch 源码解析与优化实战》第5章:选主流程