0

0

实习生级别:React 中的生命周期方法和 Hooks

WBOY

WBOY

发布时间:2024-07-17 09:07:14

|

830人浏览过

|

来源于dev.to

转载

实习生级别:react 中的生命周期方法和 hooks

react hook 简介

react hooks 是允许您在功能组件中使用状态和其他 react 功能的函数。在钩子之前,状态逻辑仅在类组件中可用。 hooks 为您已经了解的 react 概念提供了更直接的 api,例如状态、生命周期方法和上下文。

react 中的关键 hook

使用状态

usestate 是一个钩子,可让您向功能组件添加状态。

示例:

import react, { usestate } from 'react';

const counter = () => {
  const [count, setcount] = usestate(0);

  return (
    

you clicked {count} times

); }; export default counter;

在这个例子中,usestate 将 count 状态变量初始化为 0。setcount 函数用于在单击按钮时更新状态。

使用效果

useeffect 是一个钩子,可让您在功能组件中执行副作用,例如获取数据、直接与 dom 交互以及设置订阅。它结合了类组件中多个生命周期方法的功能(componentdidmount、componentdidupdate 和 componentwillunmount)。

示例:

import react, { usestate, useeffect } from 'react';

const datafetcher = () => {
  const [data, setdata] = usestate(null);

  useeffect(() => {
    fetch('https://api.example.com/data')
      .then(response => response.json())
      .then(data => setdata(data));
  }, []);

  return (
    
{data ?
{json.stringify(data, null, 2)}
: 'loading...'} ); }; export default datafetcher;

在此示例中,useeffect 在组件挂载时从 api 获取数据。

使用上下文

usecontext 是一个钩子,可让您访问给定上下文的上下文值。

示例:

import react, { usecontext } from 'react';

const themecontext = react.createcontext('light');

const themedcomponent = () => {
  const theme = usecontext(themecontext);

  return 
the current theme is {theme}
; }; export default themedcomponent;

在此示例中,usecontext 访问 themecontext 的当前值。

使用reducer

usereducer 是一个钩子,可让您管理功能组件中的复杂状态逻辑。它是 usestate 的替代品。

示例:

import react, { usereducer } from 'react';

const initialstate = { count: 0 };

const reducer = (state, action) => {
  switch (action.type) {
    case 'increment':
      return { count: state.count + 1 };
    case 'decrement':
      return { count: state.count - 1 };
    default:
      return state;
  }
};

const counter = () => {
  const [state, dispatch] = usereducer(reducer, initialstate);

  return (
    

count: {state.count}

); }; export default counter;

在这个例子中,usereducer通过reducer函数来管理计数状态。

定制挂钩

自定义挂钩让您可以跨多个组件重用有状态逻辑。自定义钩子是使用内置钩子的函数。

Android开发指南中文pdf版
Android开发指南中文pdf版

Android开发指南中文pdf版,学习android的朋友可以参考下。应用程序基础Application Fundamentals 关键类 应用程序组件 激活组件:intent 关闭组件 manifest文件 Intent过滤器 Activity和任务 Affinity(吸引力)和新任务 加载模式 清理堆栈 启动任务 进程和线程 进程 线程 远程过程调用 线程安全方法 组件生命周期 Activity生命周期 调用父类 服务生命周期 广播接收器生命周期 进程与生命周期 用户界面User Interface

下载

示例:

import { usestate, useeffect } from 'react';

const usefetch = (url) => {
  const [data, setdata] = usestate(null);

  useeffect(() => {
    fetch(url)
      .then(response => response.json())
      .then(data => setdata(data));
  }, [url]);

  return data;
};

const datafetcher = ({ url }) => {
  const data = usefetch(url);

  return (
    
{data ?
{json.stringify(data, null, 2)}
: 'loading...'} ); }; export default datafetcher;

在此示例中,usefetch 是一个自定义钩子,用于从给定 url 获取数据。

高级钩子模式

使用 usereducer 管理复杂状态

当处理涉及多个子值的复杂状态逻辑或当下一个状态依赖于前一个状态时,usereducer 可能比 usestate 更合适。

示例:

import react, { usereducer } from 'react';

const initialstate = { count: 0 };

const reducer = (state, action) => {
  switch (action.type) {
    case 'increment':
      return { count: state.count + 1 };
    case 'decrement':
      return { count: state.count - 1 };
    default:
      return state;
  }
};

const counter = () => {
  const [state, dispatch] = usereducer(reducer, initialstate);

  return (
    

count: {state.count}

); }; export default counter;

在这个例子中,usereducer通过reducer函数来管理计数状态。

使用 usememo 和 usecallback 优化性能

使用备忘录

usememo 是一个钩子,它可以记忆计算值,仅当依赖项之一发生变化时才重新计算它。它通过防止每次渲染时进行昂贵的计算来帮助优化性能。

示例:

import react, { usestate, usememo } from 'react';

const expensivecalculation = ({ number }) => {
  const computefactorial = (n) => {
    console.log('computing factorial...');
    return n <= 1 ? 1 : n * computefactorial(n - 1);
  };

  const factorial = usememo(() => computefactorial(number), [number]);

  return 
factorial of {number} is {factorial}
; }; const app = () => { const [number, setnumber] = usestate(5); return (
setnumber(parseint(e.target.value, 10))} />
); }; export default app;

在此示例中,usememo 确保仅当数字发生变化时才重新计算阶乘计算。

使用回调

usecallback 是一个用于记忆函数的钩子,防止在每次渲染时重新创建该函数,除非其依赖项之一发生更改。它对于将稳定的函数传递给依赖引用相等的子组件很有用。

示例:

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

const Button = React.memo(({ onClick, children }) => {
  console.log(`Rendering button - ${children}`);
  return ;
});

const App = () => {
  const [count, setCount] = useState(0);

  const increment = useCallback(() => setCount((c) => c + 1), []);

  return (
    

Count: {count}

); }; export default App;

在此示例中,usecallback 确保仅在其依赖项发生变化时才重新创建增量函数,从而防止 button 组件不必要的重新渲染。

结论

理解 react hooks 对于现代 react 开发至关重要。它们使您能够在功能组件中编写更清晰、更易于维护的代码。通过掌握 usestate、useeffect、usecontext 和 usereducer 等挂钩,以及自定义挂钩等高级模式以及 usememo 和 usecallback 的性能优化,您可以构建健壮且高效的 react 应用程序。作为一名实习生,扎实掌握这些概念将为您的 react 开发之旅奠定坚实的基础。

相关标签:

本站声明:本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn

相关专题

更多
counta和count的区别
counta和count的区别

Count函数用于计算指定范围内数字的个数,而CountA函数用于计算指定范围内非空单元格的个数。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

196

2023.11.20

python如何计算数的阶乘
python如何计算数的阶乘

方法:1、使用循环;2、使用递归;3、使用math模块;4、使用reduce函数。更多详细python如何计算数的阶乘的内容,可以阅读下面的文章。

166

2023.11.13

python求阶乘教程大全
python求阶乘教程大全

本专题整合了python求阶乘相关教程,阅读专题下面的文章了解更多详细内容。

9

2025.11.08

python语言求阶乘
python语言求阶乘

本专题整合了python中阶乘相关教程,阅读专题下面的文章了解更多详细步骤。

27

2025.12.06

DOM是什么意思
DOM是什么意思

dom的英文全称是documentobjectmodel,表示文件对象模型,是w3c组织推荐的处理可扩展置标语言的标准编程接口;dom是html文档的内存中对象表示,它提供了使用javascript与网页交互的方式。想了解更多的相关内容,可以阅读本专题下面的文章。

2903

2024.08.14

PHP 高并发与性能优化
PHP 高并发与性能优化

本专题聚焦 PHP 在高并发场景下的性能优化与系统调优,内容涵盖 Nginx 与 PHP-FPM 优化、Opcode 缓存、Redis/Memcached 应用、异步任务队列、数据库优化、代码性能分析与瓶颈排查。通过实战案例(如高并发接口优化、缓存系统设计、秒杀活动实现),帮助学习者掌握 构建高性能PHP后端系统的核心能力。

98

2025.10.16

PHP 数据库操作与性能优化
PHP 数据库操作与性能优化

本专题聚焦于PHP在数据库开发中的核心应用,详细讲解PDO与MySQLi的使用方法、预处理语句、事务控制与安全防注入策略。同时深入分析SQL查询优化、索引设计、慢查询排查等性能提升手段。通过实战案例帮助开发者构建高效、安全、可扩展的PHP数据库应用系统。

72

2025.11.13

JavaScript 性能优化与前端调优
JavaScript 性能优化与前端调优

本专题系统讲解 JavaScript 性能优化的核心技术,涵盖页面加载优化、异步编程、内存管理、事件代理、代码分割、懒加载、浏览器缓存机制等。通过多个实际项目示例,帮助开发者掌握 如何通过前端调优提升网站性能,减少加载时间,提高用户体验与页面响应速度。

25

2025.12.30

Java 项目构建与依赖管理(Maven / Gradle)
Java 项目构建与依赖管理(Maven / Gradle)

本专题系统讲解 Java 项目构建与依赖管理的完整体系,重点覆盖 Maven 与 Gradle 的核心概念、项目生命周期、依赖冲突解决、多模块项目管理、构建加速与版本发布规范。通过真实项目结构示例,帮助学习者掌握 从零搭建、维护到发布 Java 工程的标准化流程,提升在实际团队开发中的工程能力与协作效率。

3

2026.01.12

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号