React 中与生命周期相关的 Hooks 及其使用示例

这篇具有很好参考价值的文章主要介绍了React 中与生命周期相关的 Hooks 及其使用示例。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

React 16.8 引入了 Hooks 的概念,使得函数组件也可以使用 state 和生命周期等特性。与生命周期相关的 Hooks 主要有以下三个:

  1. useEffect

useEffect 是最常用的一个 Hook,它可以用来替代 class 组件中的 componentDidMount、componentDidUpdate 和 componentWillUnmount 这三个生命周期函数。useEffect 的作用是在函数组件渲染完成后执行某些操作,例如发送网络请求、操作 DOM 等。

useEffect 接受两个参数:第一个参数是一个回调函数,第二个参数是一个数组,用来指定哪些状态变量发生变化时需要重新执行回调函数。如果不传第二个参数,那么每次渲染都会执行回调函数。

示例代码:

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

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

  useEffect(() => {
    document.title = `You clicked ${count} times`;
  }, [count]);

  return (
    <div>
      <p>You clicked {count} times</p>
      <button onClick={() => setCount(count + 1)}>
        Click me
      </button>
    </div>
  );
}

在这个示例中,useEffect 函数在组件挂载后和每次 count 状态变化时都会调用,用于更新文档标题。

  1. useLayoutEffect

useLayoutEffect 的作用与 useEffect 类似,但它在所有 DOM 变更之后同步调用回调函数,而不是在浏览器绘制之前调用回调函数。这意味着 useLayoutEffect 可以用来处理需要立即更新 DOM 的情况,例如测量 DOM 元素的大小和位置。

示例代码:

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

function Example() {
  const [width, setWidth] = useState(window.innerWidth);

  useLayoutEffect(() => {
    function updateWidth() {
      setWidth(window.innerWidth);
    }
    window.addEventListener('resize', updateWidth);
    return () => {
      window.removeEventListener('resize', updateWidth);
    };
  }, []);

  return <p>Window width: {width}</p>;
}

在这个示例中,useLayoutEffect 函数在组件挂载后立即调用,用于监听窗口大小变化,并在窗口大小变化时更新状态。

  1. useMemo

useMemo 是一个用于优化组件性能的 Hook,它可以用来缓存计算结果,避免在每次渲染时都重新计算。useMemo 接受两个参数:第一个参数是一个函数,用来计算结果,第二个参数是一个数组,用来指定哪些状态变量发生变化时需要重新计算结果。

示例代码:

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

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

  const result = useMemo(() => {
    return count * factor;
  }, [count, factor]);

  return (
    <div>
      <p>Count: {count}</p>
      <p>Factor: {factor}</p>
      <p>Result: {result}</p>
      <button onClick={() => setCount(count + 1)}>Add count</button>
      <button onClick={() => setFactor(factor + 1)}>Add factor</button>
    </div>
  );
}

在这个示例中,useMemo 函数用于缓存 count 和 factor 的乘积,避免在每次渲染时都重新计算。只有当 count 或 factor 发生变化时,才会重新计算结果。

总之,这些与生命周期相关的 Hooks 为函数组件提供了更加灵活和高效的方式来处理状态和生命周期事件。文章来源地址https://www.toymoban.com/news/detail-850528.html

到了这里,关于React 中与生命周期相关的 Hooks 及其使用示例的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • ahooks.js:一款强大的React Hooks库及其API使用教程(四)

    ahooks是一款由阿里巴巴开发团队设计的React Hooks库,提供了一系列实用的React Hooks,以便开发者更好地使用React的功能。ahooks的设计原则是“最小API,最大自由”,旨在提供最小的、最易于理解和使用的API,同时保留最大的使用自由度。 使用npm或yarn安装ahooks: API介绍合集:

    2024年02月11日
    浏览(28)
  • ahooks.js:一款强大的React Hooks库及其API使用教程(一)

    ahooks是一款由阿里巴巴开发团队设计的React Hooks库,提供了一系列实用的React Hooks,以便开发者更好地使用React的功能。ahooks的设计原则是“最小API,最大自由”,旨在提供最小的、最易于理解和使用的API,同时保留最大的使用自由度。 使用npm或yarn安装ahooks: 1. useRequest useR

    2024年02月12日
    浏览(22)
  • ahooks.js:一款强大的React Hooks库及其API使用教程(二)

    ahooks是一款由阿里巴巴开发团队设计的React Hooks库,提供了一系列实用的React Hooks,以便开发者更好地使用React的功能。ahooks的设计原则是“最小API,最大自由”,旨在提供最小的、最易于理解和使用的API,同时保留最大的使用自由度。 使用npm或yarn安装ahooks: 前面的API:aho

    2024年02月12日
    浏览(26)
  • 【小程序全面解析】生命周期、常用组件,代码示例和使用场景

    ✍创作者:全栈弄潮儿 🏡 个人主页: 全栈弄潮儿的个人主页 🏙️ 个人社区,欢迎你的加入:全栈弄潮儿的个人社区 📙 专栏地址:小程序从入门到精通 【分享几个国内免费可用的ChatGPT镜像】 【10几个类ChatGPT国内AI大模型】 【用《文心一言》1分钟写一篇博客简直yyds】

    2023年04月09日
    浏览(59)
  • Angular 17+ 高级教程 – Component 组件 の 生命周期钩子 (Lifecycle Hooks)

    之前在 Component 组件 の Angular Component vs Custom Elements 文章中,我们有学习过几个基础的 Lifecycle Hooks。 比如 OnChanges、OnInit、AfterViewInit、OnDestroy,但那篇只是微微带过而已。 这篇让我们来深入理解 Angular 的 Lifecycle Hooks。   在 Component 组件 の Dependency Injection NodeInjector 文章中

    2024年03月09日
    浏览(41)
  • 微信小程序中的所有生命周期钩子函数及其使用方法

    onLaunch(options) :小程序初始化时触发,全局只触发一次。 onShow(options) :小程序启动或从后台进入前台显示时触发。 onHide() :小程序从前台进入后台时触发。 onError(error) :小程序发生脚本错误或 API 调用失败时触发。 onLoad(options) :页面加载时触发,可以获取页面参数。 onS

    2024年02月09日
    浏览(35)
  • react中使用shouldComponentUpdate生命周期函数调用setState引起的无限循环的错误

    在 React 组件中,当在 componentWillUpdate 或 componentDidUpdate 生命周期方法中调用 setState 时,会触发无限循环,导致超过最大更新深度。 在React组件中 ,我们使用componentWillUpdate 或 componentDidUpdate 生命周期方法中调用 setState 方法,但是调用seState会导致组件重新渲染 ,那么这个生命

    2024年02月12日
    浏览(33)
  • 【React】: React的生命周期

    生命周期的每个阶段总是伴随着一些方法的调用,这些方法就是生命周期的钩子函数 钩子函数的作用:为开发人员在不同操作阶段提供了十几 只有 类组件 才有生命周期   生命周期的图片:  同时有:  编写以下代码,从而验证constructor,render,componentDidMount的顺序: 在开发者

    2024年02月08日
    浏览(36)
  • 【React学习】React组件生命周期

    在 React 中,组件的生命周期是指组件从被创建到被销毁的整个过程。React框架提供了一系列生命周期方法,在不同的生命周期方法中,开发人员可以执行不同的操作,例如初始化状态、数据加载、渲染、更新等。一个组件的生命周期大致可以分为三个阶段,即组件挂载时,更

    2024年02月12日
    浏览(29)
  • 【react】react生命周期钩子函数:

    一、生命周期概念: 生命周期:简单来说就是一个事物从出生到消亡的过程就是生命周期,在React中的生命周期,就是组件从创建、挂载到页面再到卸载组件的过程。 意义:生命周期有助于理解组件运行方式、完成复杂组件功能、分析组件中间问题产生的原因等。 生命周期钩子函数

    2024年02月14日
    浏览(39)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包