React 中常见的Hooks,安排!

哈喽小伙伴们大家好!我是小李,今天是年后开工的第一天,相信大家已经元气满满,准备好迎接新的一年的挑战了吧!打起精神来,我们继续加油呀!今天,给大家分享一道我之前面试被问到相关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 等。它类似于 componentDidMountcomponentDidUpdatecomponentWillUnmount 这几个生命周期方法的组合。

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;

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

相关推荐
'tubug'16 分钟前
Fiddler Classic(HTTP流量代理+半汉化)
前端·http·网络安全·fiddler
Monly212 小时前
Vue:Table合并行于列
前端·javascript·vue.js
No Silver Bullet2 小时前
ReactNative进阶(五十九):存量 react-native 项目适配 HarmonyOS NEXT
react native·react.js·harmonyos
ak啊2 小时前
开发一款 VSCode 插件
前端
子非鱼9213 小时前
使用ES5和ES6求函数参数的和、解析URL Params为对象
前端·javascript·es6
zhanggongzichu3 小时前
零基础Vue入门6——Vue router
前端·javascript·vue.js·vue3·路由·vue router
江湖行骗老中医3 小时前
React Native 开发 安卓项目构建工具Gradle的配置和使用
android·react native·react.js
stark张宇4 小时前
Web - CSS3过渡与动画
前端·css·css3
ssrswk94 小时前
通过制作docker镜像的方式在阿里云部署前端后台服务
前端·阿里云·docker