react hooks

1 useEffect(setup,dependencies)

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

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

当useEffect依赖于外部传入props对象时,容易造成死循环

需要对依赖对象进行深比较

javascript 复制代码
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:

javascript 复制代码
const ref = useRef(null)
<input ref={ref} />

获取子元素的ref

javascript 复制代码
const children = forwardRef((props,ref)=>{
	return (
		<Input ref={ref}/>
	)
})

3 useContext

跨层级传递变量

javascript 复制代码
const ThemeContext = createContext(null)

<ThemeContext.Provider value='dark'>
	<Form>
<ThemeContext.Provider/>

//使用context
const context = useContext(ThemeContext)

通过context更新对象

javascript 复制代码
	<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会跳过组件和子组件的重新渲染

用法:

javascript 复制代码
//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,需要子组件能视觉上跳出当前容器

javascript 复制代码
import {createPortal} from 'react-dom'

<div>
	{
		createPortal(<p />, document.body)	
	}
</div>
相关推荐
玩电脑的辣条哥2 小时前
Python如何播放本地音乐并在web页面播放
开发语言·前端·python
ew452182 小时前
ElementUI表格表头自定义添加checkbox,点击选中样式不生效
前端·javascript·elementui
suibian52352 小时前
AI时代:前端开发的职业发展路径拓宽
前端·人工智能
画月的亮2 小时前
element-ui 使用过程中遇到的一些问题及解决方法
javascript·vue.js·ui
Moon.92 小时前
el-table的hasChildren不生效?子级没数据还显示箭头号?树形数据无法展开和收缩
前端·vue.js·html
m0_526119402 小时前
点击el-dialog弹框跳到其他页面浏览器的滚动条消失了多了 el-popup-parent--hidden
javascript·vue.js·elementui
垚垚 Securify 前沿站2 小时前
深入了解 AppScan 工具的使用:筑牢 Web 应用安全防线
运维·前端·网络·安全·web安全·系统安全
工业甲酰苯胺5 小时前
Vue3 基础概念与环境搭建
前端·javascript·vue.js
lyj1689975 小时前
el-tree选中数据重组成树
javascript·vue.js·elementui
mosquito_lover16 小时前
怎么把pyqt界面做的像web一样漂亮
前端·python·pyqt