React 中常见的Hooks,安排!

ops/2025/2/9 2:07:34/

哈喽小伙伴们大家好!我是小李,今天是年后开工的第一天,相信大家已经元气满满,准备好迎接新的一年的挑战了吧!打起精神来,我们继续加油呀!今天,给大家分享一道我之前面试被问到相关Hooks的一道题目,今天先来说说react的,下期文章为大家分享vue的,希望对大家有所帮助!

首先,什么是Hooks?为什么会有Hooks这个东西?

所谓Hooks,它其实就是一些特殊的函数,也称钩子函数,它允许开发者在不编写 class 的情况下使用 state 以及其他 React 特性。简单来说,Hooks 就是一些特殊的函数,这些函数可以让你 “钩入”(Hook into) React 的状态和生命周期等特性。

1、useState

用于在函数组件中添加 statestate 是 React 组件中的一个重要概念,它允许组件存储和管理动态数据。

import React, { useState } from 'react';function Counter() {const [count, setCount] = useState(0);return (<div><p>You clicked {count} times</p><button onClick={() => setCount(count + 1)}>Click me</button></div>);
}export default Counter;
2、useEffect

用于处理副作用操作,比如数据获取、订阅、手动修改 DOM 等。它类似于 componentDidMountcomponentDidUpdate 和 componentWillUnmount 这几个生命周期方法的组合。

import React, { useState, useEffect } from 'react';function Example() {const [count, setCount] = useState(0);useEffect(() => {// 更新文档标题document.title = `You clicked ${count} times`;});return (<div><p>You clicked {count} times</p><button onClick={() => setCount(count + 1)}>Click me</button></div>);
}export default Example;
3、useContext

用于在组件之间共享数据,避免通过中间组件层层传递 props。它需要和 React.createContext 一起使用。

import React, { createContext, useContext, useState } from 'react';// 创建一个 Context 对象
const ThemeContext = createContext();function App() {const [theme, setTheme] = useState('light');return (<ThemeContext.Provider value={theme}><Toolbar /><button onClick={() => setTheme(theme === 'light' ? 'dark' : 'light')}>Toggle Theme</button></ThemeContext.Provider>);
}function Toolbar() {return (<div><ThemedButton /></div>);
}function ThemedButton() {// 使用 useContext 获取 ThemeContext 的值const theme = useContext(ThemeContext);return <button style={{ background: theme === 'light' ? 'white' : 'black', color: theme === 'light' ? 'black' : 'white' }}>Themed Button</button>;
}export default App;

接下来是一些不常见的。

1、useReducer

是 useState 的替代方案,适用于复杂的 state 逻辑或多个子值需要更新的情况。它使用一个reducer 函数来管理 state 的更新。

import React, { useReducer } from 'react';const initialState = { count: 0 };function reducer(state, action) {switch (action.type) {case 'increment':return { count: state.count + 1 };case 'decrement':return { count: state.count - 1 };default:throw new Error();}
}function Counter() {const [state, dispatch] = useReducer(reducer, initialState);return (<>Count: {state.count}<button onClick={() => dispatch({ type: 'increment' })}>+</button><button onClick={() => dispatch({ type: 'decrement' })}>-</button></>);
}export default Counter;
2、useCallback

返回一个 memoized 回调函数,用于优化性能。当父组件重新渲染时,使用 useCallback 可以避免子组件因为传入的回调函数引用变化而不必要地重新渲染。

import React, { useState, useCallback } from 'react';function Parent() {const [count, setCount] = useState(0);// 使用 useCallback 缓存回调函数const handleClick = useCallback(() => {console.log('Button clicked');}, []);return (<div><p>Count: {count}</p><button onClick={() => setCount(count + 1)}>Increment</button><Child onClick={handleClick} /></div>);
}function Child({ onClick }) {return <button onClick={onClick}>Click me</button>;
}export default Parent;
3、useMemo

返回一个 memoized 值,用于优化性能。它会在依赖项发生变化时重新计算值,避免在每次渲染时都进行昂贵的计算。

import React, { useState, useMemo } from 'react';function App() {const [a, setA] = useState(1);const [b, setB] = useState(2);// 使用 useMemo 缓存计算结果const sum = useMemo(() => {console.log('Calculating sum...');return a + b;}, [a, b]);return (<div><p>a: {a}</p><p>b: {b}</p><p>Sum: {sum}</p><button onClick={() => setA(a + 1)}>Increment a</button><button onClick={() => setB(b + 1)}>Increment b</button></div>);
}export default App;
4、useRef

返回一个可变的 ref 对象,其 .current 属性被初始化为传入的参数。它可以用来访问 DOM 节点或在多次渲染之间保存值。

import React, { useRef } from 'react';function TextInputWithFocusButton() {const inputEl = useRef(null);const onButtonClick = () => {// `current` 指向已挂载到 DOM 上的文本输入元素inputEl.current.focus();};return (<><input ref={inputEl} type="text" /><button onClick={onButtonClick}>Focus the input</button></>);
}export default TextInputWithFocusButton;

好啦,今天的分享就到这里,整理不易,如果觉得对你有帮助,欢迎给个三连支持,我是小李,我们下期见!


http://www.ppmy.cn/ops/156854.html

相关文章

基于C#语言的海康威视智能车牌识别系统

基于C#语言的海康威视智能车牌识别系统&#xff0c;通过布控对来往车辆进行检测抓拍 资源文件列表 AICar.sln , 984 AICar.sln.GhostDoc.xml , 1306 AICar.v12.suo , 72704 AICar/AICar.csproj , 3573 AICar/AICar.csproj.user , 228 AICar/bin/Debug/AICar.exe , 220672 AIC…

【戒抖音系列】短视频戒除-1-对推荐算法进行干扰

如今推荐算法已经渗透到人们生活的方方面面&#xff0c;尤其是抖音等短视频核心就是推荐算法。 【短视频的危害】 1> 会让人变笨&#xff0c;慢慢让人丧失注意力与专注力 2> 让人丧失阅读长文的能力 3> 让人沉浸在一个又一个快感与嗨点当中。当我们刷短视频时&#x…

【MySQL】详解数据库约束、聚合查询和联合查询

数据库约束 约束类型 数据库的约束类型主要包括以下几种&#xff1a; 主键约束&#xff08;Primary Key Constraint&#xff09;&#xff1a;确保表中的每一行都有唯一的标识&#xff0c;且不能为NULL。 外键约束&#xff08;Foreign Key Constraint&#xff09;&#xff1a…

TensorFlow 与 PyTorch 的直观区别

背景 TensorFlow 与 PyTorch 都是比较流行的深度学习框架。tf 由谷歌在 2015 年发布&#xff0c;而 PyTorch 则是 Facecbook AI 研究团队 2016 年在原来 Torch 的基础上发布的。 tf 采用的是静态计算图。这意味着在执行任何计算之前&#xff0c;你需要先定义好整个计算图&…

RabbitMQ 从入门到精通:从工作模式到集群部署实战(五)

#作者&#xff1a;闫乾苓 系列前几篇&#xff1a; 《RabbitMQ 从入门到精通&#xff1a;从工作模式到集群部署实战&#xff08;一&#xff09;》&#xff1a;link 《RabbitMQ 从入门到精通&#xff1a;从工作模式到集群部署实战&#xff08;二&#xff09;》&#xff1a; lin…

【Day32 LeetCode】动态规划DP Ⅴ 完全背包

一、动态规划DP Ⅴ 完全背包 1、完全背包理论 有N件物品和一个最多能背重量为W的背包。第i件物品的重量是weight[i]&#xff0c;得到的价值是value[i] 。每件物品都有无限个&#xff08;也就是可以放入背包多次&#xff09;&#xff0c;求解将哪些物品装入背包里物品价值总和…

https是如何保证安全的,又是如何保证不被中间人攻击的?

HTTPS如何保证安全&#xff0c;以及如何防止中间人攻击 保护用户隐私和数据安全已经成为了一个不可忽视的问题。随着网络攻击的不断升级&#xff0c;HTTPS&#xff08;超文本传输安全协议&#xff09;成为了我们在网络上交流时的一道重要防线。以下是HTTPS是如何保证安全的&am…

HTML之基本布局div|span

HTML基本布局使用 <!DOCTYPE html> <html lang"en"> <head><meta charset"UTF-8"><meta name"viewport" content"width<device-width>, initial-scale1.0"><title>布局</title> <…