react的hooks

  1. useState:状态管理---在函数组件中添加响应式状态。

例:

javascript 复制代码
const [count, setCount] = useState(0);
setCount(5)//更新count的值

相当于vue的 ref / reactive:

javascript 复制代码
const count = ref(0)
count.value = 5

2.useEffect:副作用处理---处理副作用(数据获取、订阅、DOM操作等)。

例:

javascript 复制代码
useEffect(()=>{
  //组件挂载或更新时执行
  document.title = `Count:${count}`;
  return()=>{
   //清理函数(组件卸载或依赖变化前执行)
   console.log('清理')
  }
},[count]) //依赖数组

相当于vue的 watch / watchEffect:

javascript 复制代码
watch(count,(newVal)=>{
  document.title = `Count:${newVal}`
  return ()=> console.log('清理');
})

//或者使用watchEffect
watchEffect(()=>{
   document.title = `Count:${count.value}`
})

3.useContext:跨组件数据传递---无需props层层传递,直接获取上下文数据。

javascript 复制代码
const ThemeContent = createContext('light')
const theme = useContext(ThemeContent )

相当于vue的provide / inject:

javascript 复制代码
import {inject} from 'vue'
const theme = inject('theme')

4.useReducer:复杂状态管理---适用于复杂状态逻辑(类似redux)。

javascript 复制代码
const [state,dispatch] = useReducer(reducer,initialState);
dispatch({type:'increment'})

相当于vue的pinia:

javascript 复制代码
const state = reactive({count:0});
function dispatch(action){
  if(action.type === 'increment') state.count++
}

5.useRef:引用/DOM访问

javascript 复制代码
const inputRef = useRef(null);
<input ref={inputRef} />
inputRef.current.focus()//访问dom

相当于vue的ref:

javascript 复制代码
const inputRef = ref(null);
<input ref="inputRef" />
inputRef.value.focus(); // 访问DOM

6.useMemo:记忆化计算---缓存计算结果,优化性能

javascript 复制代码
//computeExpensiveValue是开发者自定义的复杂的计算函数
const expensiveValue = useMemo(()=>{
   return computeExpensiveValue(a,b);
},[a,b])//只有a或者b变化时才重新计算

相当于vue的computed:

javascript 复制代码
const expensiveValue = computed(()=>{
  return computeExpensiveValue(a.value,b.value)
})//computeExpensiveValue是开发者自定义的复杂的计算函数

7.useCallback:记忆化函数---缓存函数引用,避免子组件不必要的重新渲染。

javascript 复制代码
const handleClick = useCallback(()=>{
  console.log(count)
},[count])//依赖变化时才重新创建函数

相当于vue的手动优化,只有一依赖变化时才执行的函数:

javascript 复制代码
const handleClick = ()=>{
   console.log(count.value)
}

8.useLayoutEffect:同步副作用---在DOM更新后、浏览器绘制前同步执行。

javascript 复制代码
useLayoutEffect(()=>{
//DOM更新后同步执行(在浏览器绘制前)
  measureDOM()
},[deps])

相当于vue的nextTick + watch:

javascript 复制代码
// Vue 3(nextTick + watch)
watch(someRef, () => {
  nextTick(() => {
    measureDOM();
  });
});

9.自定义Hooks:逻辑复用

javascript 复制代码
//自定义Hooks
function useLocalStorage(key,initialValue){
  const [value,setValue] = useState(()=>{
    const stored = localStorage.getItem(key)
    return stored ? Json.Parse(stored) : initialValue
  })
   
  useEffect(()=>{
     localStorage.setItem(key.Json.stringify(value));
  },[key,value])

  return [value,setValue]
}

//使用
 const [name,setName] = useLocalStorage('name','默认名')

相当于vue:

javascript 复制代码
//vue3自定义组合函数
function useLocalStorage(key,initialValue)=>{
  const value = ref(initialValue);
  const stored = localStorage.getItem(key);
  if(storde) value.value = Json.parse(stored)

  watch(value,(newVal)=>{
    localStorage.setItem(key,Json.stringfy(newValue))
  })
  
  return {value}
}

//使用
const {value:name} = useLocalStorage('name','默认名')
相关推荐
于慨16 小时前
Lambda 表达式、方法引用(Method Reference)语法
java·前端·servlet
石小石Orz16 小时前
油猴脚本实现生产环境加载本地qiankun子应用
前端·架构
从前慢丶16 小时前
前端交互规范(Web 端)
前端
@yanyu66616 小时前
07-引入element布局及spring boot完善后端
javascript·vue.js·spring boot
CHU72903516 小时前
便捷约玩,沉浸推理:线上剧本杀APP功能版块设计详解
前端·小程序
GISer_Jing16 小时前
Page-agent MCP结构
前端·人工智能
王霸天16 小时前
💥别再抄网上的Scale缩放代码了!50行源码教你写一个永不翻车的大屏适配
前端·vue.js·数据可视化
小领航16 小时前
用 Three.js + Vue 3 打造炫酷的 3D 行政地图可视化组件
前端·github
@大迁世界16 小时前
2026年React大洗牌:React Hooks 将迎来重大升级
前端·javascript·react.js·前端框架·ecmascript
PieroPc16 小时前
一个功能强大的 Web 端标签设计和打印工具,支持服务器端直接打印到局域网打印机。Fastapi + html
前端·html·fastapi