”工欲善其事,必先利其器。“—孔子《论语.录灵公》
首页 > 编程 > React HooK= { 简要解释};

React HooK= { 简要解释};

发布于2024-11-08
浏览:631

React HooK= { Briefly Explained};

useState 是一个 React Hook,它允许您通过返回包含两个变量的数组来向组件添加状态:state、setState。当前状态以及调用时成为 setter 函数的函数。它可用于跟踪应用程序中需要跟踪的数据或属性,例如字符串、数字、布尔值、数组或对象。
例子:

const [state, setState] = useState();

简单来说,状态会在任何时候发生变化并且需要更新,因此“setState”将更新状态,随着时间的推移触发组件的重新渲染。

此外,useState 可以保存任何类型的 Javascript 值,包括对象。始终记住的一点是,您永远不应该直接更改处于 React 状态的对象。首先,您需要创建一个新副本或创建现有副本的副本,然后将 State 设置为新副本。例如:

// Objects
const [state, setState] = useState({name: 'Marlo', age: 56});

const updateName = () => {
  setState({...state, name: 'Karlo'});
};

const updateAge = () => {
  setState({...state, age: 96});
};
---------------------------------------------------------------------------------
// Arrays
const [array, setArray] = useState([1, 2, 3, 4, 5]);

const addItem = () => {
  setArray([...array, 6]);
};

const removeItem = () => {
  setArray(array.slice(0, array.length - 1));
};

要在React组件中使用useState,首先需要从React导入它,方法是在组件页面顶部以两种不同的方式编写以下代码,两种方式都有效完美地让你可以选择你的毒药。

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

或者你可以写在一行

import React, {useState} from 'react';

React 钩子 useState 可以在组件的顶层或自定义钩子内调用,但不能在循环或条件内调用。

const [initialState, setInitialState] = useState();

initialState 仅在初始渲染期间使用,在后续渲染中将被忽略。
initialState函数被传递给setInitialState函数,它以之前的状态作为参数,并返回一个newState。

此外,在我看来,对于在 React 中什么地方可以使用 Hooks 和什么地方不可以使用 Hooks 没有特殊的规则。当然,您必须谨慎且有策略地保持代码井井有条。

在我的一个项目中,构建 SPA(单页应用程序)有各种组件来实现我的目标。组织良好的秘诀是跟踪您的组件。例如,您的 App.js 组件将根据需要更新的数据类型使用 {useState}。
让我们介绍另一个来自 React 的强大钩子:{useEffect},并使用它和 {useState} 来解释这些钩子如何对数据执行操作。以下示例来自我在最近的项目中使用的 App.js 组件。我正在处理玩具的 db.json 文件数据,这将有助于儿童第一年的发展。这是我的端点 http://localhost:4000/toys 来帮助您了解 {useState} 和 {useEffect} 如何在应用程序组件内部工作的过程。

第一:初始化状态:

const [toys, setToys] = useState([]);
  • 这一行用空数组[]作为初始值初始化状态变量toys。
  • setToys 是一个用于更新玩具状态的函数。

第二: 获取组件安装数据:

useEffect(() => {             
    fetch("http://localhost:4000/toys")  
      .then(response => response.json())
      .then(data => setToys(data)); 
  }, []);
  • {useEffect} 钩子用于在组件中执行副作用。
  • {useEffect} 中的函数将在组件挂载时运行一次,因为依赖数组 ([]) 为空。

第三: 获取玩具数据:

  • fetch("http://localhost:4000/toys")
    • 此行向指定的 URL 发出 GET 请求以获取玩具数据。
  • .then(响应=>response.json())
    • 获取请求的响应被转换为 JSON 格式。
  • .then(toysData => setToyData(toysData));
    • JSON 数据 (toysData) 用于使用 setToys 函数更新玩具状态。

要更深入地了解 {useState, useEffect} 的工作原理,您可以访问 React 官方网站。此外,另一个有用的来源是 w3schools 网站,这是我个人最喜欢的。它开门见山地提供了示例,您可以在自己的浏览器中尝试。最后,如果您需要更多技术资源,mdn 网络文档将为您提供帮助。

版本声明 本文转载于:https://dev.to/marlonmunoz/react-hook-briefly-explained-4k74?1如有侵犯,请联系[email protected]删除
最新教程 更多>
  • C++中如何将独占指针作为函数或构造函数参数传递?
    C++中如何将独占指针作为函数或构造函数参数传递?
    在构造函数和函数中将唯一的指数管理为参数 unique pointers( unique_ptr [2启示。通过值: base(std :: simelor_ptr n) :next(std :: move(n)){} 此方法将唯一指针的所有权转移到函数/对象。指针的内容被移至功能中,在操作...
    编程 发布于2025-05-08
  • 在Java中如何为PNG文件添加坐标轴和标签?
    在Java中如何为PNG文件添加坐标轴和标签?
    如何用java 在现有png映像中添加轴和标签的axes和labels如何注释png文件可能具有挑战性。与其尝试可能导致错误和不一致的修改,不如建议在图表创建过程中集成注释。使用JFReechArt import java.awt.color; 导入java.awt.eventqueue; 导入...
    编程 发布于2025-05-08
  • 如何在其容器内为DIV创建平滑的左右CSS动画?
    如何在其容器内为DIV创建平滑的左右CSS动画?
    通用CSS动画,用于左右运动 ,我们将探索创建一个通用的CSS动画,以向左和右移动DIV,从而到达其容器的边缘。该动画可以应用于具有绝对定位的任何div,无论其未知长度如何。问题:使用左直接导致瞬时消失 更加流畅的解决方案:混合转换和左 [并实现平稳的,线性的运动,我们介绍了线性的转换。这...
    编程 发布于2025-05-08
  • 如何有效地转换PHP中的时区?
    如何有效地转换PHP中的时区?
    在PHP 利用dateTime对象和functions DateTime对象及其相应的功能别名为时区转换提供方便的方法。例如: //定义用户的时区 date_default_timezone_set('欧洲/伦敦'); //创建DateTime对象 $ dateTime = ne...
    编程 发布于2025-05-08
  • Python不会对超范围子串切片报错的原因
    Python不会对超范围子串切片报错的原因
    在python中用索引切片范围:二重性和空序列索引单个元素不同,该元素会引起错误,切片在序列的边界之外没有。这种行为源于索引和切片之间的基本差异。索引一个序列,例如“示例” [3],返回一个项目。但是,切片序列(例如“示例” [3:4])返回项目的子序列。索引不存在的元素时,例如“示例” [9] ...
    编程 发布于2025-05-08
  • 如何将MySQL数据库添加到Visual Studio 2012中的数据源对话框中?
    如何将MySQL数据库添加到Visual Studio 2012中的数据源对话框中?
    在Visual Studio 2012 尽管已安装了MySQL Connector v.6.5.4,但无法将MySQL数据库添加到实体框架的“ DataSource对话框”中。为了解决这一问题,至关重要的是要了解MySQL连接器v.6.5.5及以后的6.6.x版本将提供MySQL的官方Visual...
    编程 发布于2025-05-08
  • 如何处理PHP文件系统功能中的UTF-8文件名?
    如何处理PHP文件系统功能中的UTF-8文件名?
    在PHP的Filesystem functions中处理UTF-8 FileNames 在使用PHP的MKDIR函数中含有UTF-8字符的文件很多flusf-8字符时,您可能会在Windows Explorer中遇到comploreer grounder grounder grounder gro...
    编程 发布于2025-05-08
  • Python元类工作原理及类创建与定制
    Python元类工作原理及类创建与定制
    python中的metaclasses是什么? Metaclasses负责在Python中创建类对象。就像类创建实例一样,元类也创建类。他们提供了对类创建过程的控制层,允许自定义类行为和属性。在Python中理解类作为对象的概念,类是描述用于创建新实例或对象的蓝图的对象。这意味着类本身是使用类关...
    编程 发布于2025-05-08
  • 如何使用Java.net.urlConnection和Multipart/form-data编码使用其他参数上传文件?
    如何使用Java.net.urlConnection和Multipart/form-data编码使用其他参数上传文件?
    使用http request 上传文件上传到http server,同时也提交其他参数,java.net.net.urlconnection and Multipart/form-data Encoding是普遍的。 Here's a breakdown of the process:Mu...
    编程 发布于2025-05-08
  • Java的Map.Entry和SimpleEntry如何简化键值对管理?
    Java的Map.Entry和SimpleEntry如何简化键值对管理?
    的综合集合:在Java中介绍Java的Map.entry和SimpleEntry和SimpleEntry和SimpleEntry和SimpleEntry和SimpleEntry和SimpleEntry和SimpleEntry和SimpleEntry apry and Map。 地图。它具有两个通用...
    编程 发布于2025-05-08
  • 您如何在Laravel Blade模板中定义变量?
    您如何在Laravel Blade模板中定义变量?
    在Laravel Blade模板中使用Elegance 在blade模板中如何分配变量对于存储以后使用的数据至关重要。在使用“ {{}}”分配变量的同时,它可能并不总是最优雅的解决方案。幸运的是,Blade通过@php Directive提供了更优雅的方法: $ old_section =“...
    编程 发布于2025-05-08
  • Android如何向PHP服务器发送POST数据?
    Android如何向PHP服务器发送POST数据?
    在android apache httpclient(已弃用) httpclient httpclient = new defaulthttpclient(); httppost httppost = new httppost(“ http://www.yoursite.com/script.p...
    编程 发布于2025-05-08
  • Java字符串非空且非null的有效检查方法
    Java字符串非空且非null的有效检查方法
    检查字符串是否不是null而不是空的if (str != null && !str.isEmpty())Option 2: str.length() == 0For Java versions prior to 1.6, str.length() == 0 can be二手: if(str!= n...
    编程 发布于2025-05-08
  • 如何克服PHP的功能重新定义限制?
    如何克服PHP的功能重新定义限制?
    克服PHP的函数重新定义限制在PHP中,多次定义一个相同名称的函数是一个no-no。尝试这样做,如提供的代码段所示,将导致可怕的“不能重新列出”错误。 但是,PHP工具腰带中有一个隐藏的宝石:runkit扩展。它使您能够灵活地重新定义函数。 runkit_function_renction_re...
    编程 发布于2025-05-08
  • 为什么使用固定定位时,为什么具有100%网格板柱的网格超越身体?
    为什么使用固定定位时,为什么具有100%网格板柱的网格超越身体?
    网格超过身体,用100%grid-template-columns 为什么在grid-template-colms中具有100%的显示器,当位置设置为设置的位置时,grid-template-colly修复了?问题: 考虑以下CSS和html: class =“ snippet-code”> g...
    编程 发布于2025-05-08

免责声明: 提供的所有资源部分来自互联网,如果有侵犯您的版权或其他权益,请说明详细缘由并提供版权或权益证明然后发到邮箱:[email protected] 我们会第一时间内为您处理。

Copyright© 2022 湘ICP备2022001581号-3