彻底学会react hooks API以及应用场景

简介: 【4月更文挑战第6天】 React Hooks是16.8版引入的新特性,允许在函数组件中使用state和其它React功能,避免类组件。主要包括useState(添加state)、useEffect(处理副作用)、useContext(访问上下文)、useReducer(使用reducer)、useCallback(缓存函数)、useMemo(缓存计算结果)和useRef(访问DOM元素)。Hooks简化了代码组织和重用,提高了代码效率和可维护性。

React Hooks 是 React 16.8 版本引入的一种新特性,它允许我们在函数组件中使用 state 和其他 React 特性,而无需编写类组件。React Hooks 提供了一种更简洁、更易于理解的方式来组织和重用代码。本文将详细介绍 React Hooks API 及其应用场景和使用方式。

  1. useState

useState 是一个用于在函数组件中添加 state 的 Hook。它接受一个初始值作为参数,并返回一个包含两个元素的数组:当前状态值和一个更新状态值的函数。

使用示例:

import React, {
    useState } from 'react';

function Counter() {
   
  const [count, setCount] = useState(0);

  return (
    <div>
      <p>当前计数: {
   count}</p>
      <button onClick={
   () => setCount(count + 1)}>+1</button>
      <button onClick={
   () => setCount(count - 1)}>-1</button>
    </div>
  );
}
  1. useEffect

useEffect 是一个用于处理副作用的 Hook,例如数据获取、订阅或手动更改 DOM。它接受两个参数:一个函数(副作用函数)和一个可选的依赖项数组。副作用函数在组件挂载后和依赖项更改时执行。如果省略依赖项数组,则副作用函数将在每次渲染后执行。

使用示例:

import React, {
    useState, useEffect } from 'react';

function Example() {
   
  const [count, setCount] = useState(0);

  useEffect(() => {
   
    document.title = `计数: ${
     count}`;
  });

  return (
    <div>
      <p>当前计数: {
   count}</p>
      <button onClick={
   () => setCount(count + 1)}>+1</button>
      <button onClick={
   () => setCount(count - 1)}>-1</button>
    </div>
  );
}
  1. useContext

useContext 是一个用于访问 React 上下文的 Hook。它接受一个上下文对象作为参数,并返回该上下文的当前值。

使用示例:

import React, {
    useContext } from 'react';
import {
    ThemeContext } from './ThemeContext';

function ThemedButton() {
   
  const theme = useContext(ThemeContext);

  return (
    <button style={
   {
    background: theme.background, color: theme.foreground }}>
      我是一个主题按钮
    </button>
  );
}
  1. useReducer

useReducer 是一个用于在函数组件中使用 reducer 的 Hook。它接受一个 reducer 函数和一个初始状态作为参数,并返回一个包含当前状态和一个 dispatch 动作的函数的数组。

使用示例:

import React, {
    useReducer } from 'react';

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, {
    count: 0 });

  return (
    <div>
      <p>当前计数: {
   state.count}</p>
      <button onClick={
   () => dispatch({
    type: 'increment' })}>+1</button>
      <button onClick={
   () => dispatch({
    type: 'decrement' })}>-1</button>
    </div>
  );
}
  1. useCallback

useCallback 是一个用于缓存函数的 Hook。它接受一个函数和一个依赖项数组作为参数,并返回一个新的记忆化函数。当依赖项更改时,记忆化函数将重新计算。

使用示例:

import React, {
    useState, useCallback } from 'react';

function Child({
    onClick }) {
   
  console.log('子组件渲染');
  return <button onClick={
   onClick}>点击我</button>;
}

function Parent() {
   
  const [count, setCount] = useState(0);
  const handleClick = useCallback(() => {
   
    setCount(count + 1);
  }, [count]);

  return (
    <div>
      <p>当前计数: {
   count}</p>
      <Child onClick={
   handleClick} />
    </div>
  );
}
  1. useMemo

useMemo 是一个用于缓存计算结果的 Hook。它接受一个函数和一个依赖项数组作为参数,并返回一个新的记忆化值。当依赖项更改时,记忆化值将重新计算。

使用示例:

import React, {
    useState, useMemo } from 'react';

function expensiveCalculation(number) {
   
  let result = 0;
  for (let i = 0; i < number * 100000; i++) {
   
    result += i;
  }
  return result;
}

function Parent() {
   
  const [count, setCount] = useState(0);
  const calculatedValue = useMemo(() => expensiveCalculation(count), [count]);

  return (
    <div>
      <p>计算结果: {
   calculatedValue}</p>
      <button onClick={
   () => setCount(count + 1)}>+1</button>
    </div>
  );
}
  1. useRef

useRef 是一个用于访问 DOM 元素的 Hook。它接受一个初始值作为参数,并返回一个可变的 ref 对象。ref 对象的 current 属性指向目标 DOM 元素。

使用示例:

import React, {
    useRef } from 'react';

function TextInputWithFocusButton() {
   
  const inputEl = useRef(null);

  const onButtonClick = () => {
   
    inputEl.current.focus();
  };

  return (
    <div>
      <input ref={
   inputEl} type="text" />
      <button onClick={
   onButtonClick}>聚焦输入框</button>
    </div>
  );
}

总结:

React Hooks 提供了一种更简洁、更易于理解的方式来组织和重用代码。通过使用不同的 Hook,我们可以在函数组件中实现 state、副作用、上下文、reducer、缓存函数、缓存计算结果和访问 DOM 元素等功能。熟练掌握这些 Hook 将有助于我们编写更高效、更易于维护的 React 应用。

目录
相关文章
|
2月前
|
存储 搜索推荐 安全
介绍几个常用的电商API接口及其应用场景。(一篇文章全清楚)
电商API接口是电商平台高效运营的核心技术支撑,涵盖商品管理、订单管理、支付、客户管理、营销推广和数据分析六大模块。商品管理API实现商品信息的精准上传与动态调整;订单管理API确保订单全流程透明可控;支付API保障交易安全便捷;客户管理API通过数据分析提供个性化服务;营销推广API助力精准营销;数据分析API为决策提供数据支持。各API协同工作,推动电商行业创新发展,构建智能便捷的电商生态。
333 12
|
2月前
|
JSON API 数据安全/隐私保护
淘宝商品详情API接口系列以及应用场景
淘宝商品详情API接口系列是淘宝开放平台提供的一系列编程接口,允许第三方开发者通过特定的协议和方式,与淘宝平台进行数据交互。这些接口涵盖了商品搜索、商品详情获取、订单管理、物流查询、支付结算等多个方面,为开发者提供了极大的灵活性和便利性。以下是对淘宝商品详情API接口系列的详细介绍
|
3月前
|
前端开发 安全 Android开发
哪些场景适合使用 React Native?
哪些场景适合使用 React Native?
146 8
|
3月前
|
前端开发 JavaScript API
探究 React Hooks:如何利用全新 API 优化组件逻辑复用与状态管理
本文深入探讨React Hooks的使用方法,通过全新API优化组件逻辑复用和状态管理,提升开发效率和代码可维护性。
|
3月前
|
前端开发
深入探索React Hooks:从useState到useEffect
深入探索React Hooks:从useState到useEffect
39 3
|
3月前
|
前端开发 JavaScript
React Hooks 深入解析
React Hooks 深入解析
44 0
|
3月前
|
前端开发
React Hooks:从基础到进阶的深入理解
React Hooks:从基础到进阶的深入理解
55 0
|
3月前
|
缓存 前端开发 开发者
深入理解React Hooks,打造高效响应式UI
深入理解React Hooks,打造高效响应式UI
48 0
|
3月前
|
前端开发 JavaScript 开发者
颠覆传统:React框架如何引领前端开发的革命性变革
【10月更文挑战第32天】本文以问答形式探讨了React框架的特性和应用。React是一款由Facebook推出的JavaScript库,以其虚拟DOM机制和组件化设计,成为构建高性能单页面应用的理想选择。文章介绍了如何开始一个React项目、组件化思想的体现、性能优化方法、表单处理及路由实现等内容,帮助开发者更好地理解和使用React。
118 9
|
4月前
|
前端开发
深入解析React Hooks:构建高效且可维护的前端应用
本文将带你走进React Hooks的世界,探索这一革新特性如何改变我们构建React组件的方式。通过分析Hooks的核心概念、使用方法和最佳实践,文章旨在帮助你充分利用Hooks来提高开发效率,编写更简洁、更可维护的前端代码。我们将通过实际代码示例,深入了解useState、useEffect等常用Hooks的内部工作原理,并探讨如何自定义Hooks以复用逻辑。