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

React HooK= { 简要解释};

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

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]删除
最新教程 更多>
  • 如何使用PHP将斑点(图像)正确插入MySQL?
    如何使用PHP将斑点(图像)正确插入MySQL?
    essue VALUES('$this->image_id','file_get_contents($tmp_image)')";This code builds a string in PHP, but the function call ...
    编程 发布于2025-06-24
  • 在Pandas中如何将年份和季度列合并为一个周期列?
    在Pandas中如何将年份和季度列合并为一个周期列?
    pandas data frame thing commans date lay neal and pree pree'和pree pree pree”,季度 2000 q2 这个目标是通过组合“年度”和“季度”列来创建一个新列,以获取以下结果: [python中的concate...
    编程 发布于2025-06-24
  • Go语言如何动态发现导出包类型?
    Go语言如何动态发现导出包类型?
    与反射软件包中的有限类型的发现能力相反,本文探索了替代方法,探索了在Runruntime。go import( “ FMT” “去/进口商” ) func main(){ pkg,err:= incorter.default()。导入(“ time”) 如果err...
    编程 发布于2025-06-24
  • 表单刷新后如何防止重复提交?
    表单刷新后如何防止重复提交?
    在Web开发中预防重复提交 在表格提交后刷新页面时,遇到重复提交的问题是常见的。要解决这个问题,请考虑以下方法: 想象一下具有这样的代码段,看起来像这样的代码段:)){ //数据库操作... 回声“操作完成”; 死(); } ?> ...
    编程 发布于2025-06-24
  • PHP SimpleXML解析带命名空间冒号的XML方法
    PHP SimpleXML解析带命名空间冒号的XML方法
    在php 很少,请使用该限制很大,很少有很高。例如:这种技术可确保可以通过遍历XML树和使用儿童()方法()方法的XML树和切换名称空间来访问名称空间内的元素。
    编程 发布于2025-06-24
  • 解决MySQL插入Emoji时出现的\\"字符串值错误\\"异常
    解决MySQL插入Emoji时出现的\\"字符串值错误\\"异常
    Resolving Incorrect String Value Exception When Inserting EmojiWhen attempting to insert a string containing emoji characters into a MySQL database us...
    编程 发布于2025-06-24
  • 如何干净地删除匿名JavaScript事件处理程序?
    如何干净地删除匿名JavaScript事件处理程序?
    删除匿名事件侦听器将匿名事件侦听器添加到元素中会提供灵活性和简单性,但是当要删除它们时,可以构成挑战,而无需替换元素本身就可以替换一个问题。 element? element.addeventlistener(event,function(){/在这里工作/},false); 要解决此问题,请考虑...
    编程 发布于2025-06-24
  • 如何使用FormData()处理多个文件上传?
    如何使用FormData()处理多个文件上传?
    )处理多个文件输入时,通常需要处理多个文件上传时,通常是必要的。 The fd.append("fileToUpload[]", files[x]); method can be used for this purpose, allowing you to send multi...
    编程 发布于2025-06-24
  • 如何避免Go语言切片时的内存泄漏?
    如何避免Go语言切片时的内存泄漏?
    ,a [j:] ...虽然通常有效,但如果使用指针,可能会导致内存泄漏。这是因为原始的备份阵列保持完整,这意味着新切片外部指针引用的任何对象仍然可能占据内存。 copy(a [i:] 对于k,n:= len(a)-j i,len(a); k
    编程 发布于2025-06-24
  • 为什么HTML无法打印页码及解决方案
    为什么HTML无法打印页码及解决方案
    无法在html页面上打印页码? @page规则在@Media内部和外部都无济于事。 HTML:Customization:@page { margin: 10%; @top-center { font-family: sans-serif; font-weight: bo...
    编程 发布于2025-06-24
  • 如何在Java中正确显示“ DD/MM/YYYY HH:MM:SS.SS”格式的当前日期和时间?
    如何在Java中正确显示“ DD/MM/YYYY HH:MM:SS.SS”格式的当前日期和时间?
    如何在“ dd/mm/yyyy hh:mm:mm:ss.ss”格式“ gormat 解决方案:的,请访问量很大,并应为procectiquiestate的,并在整个代码上正确格式不多: java.text.simpledateformat; 导入java.util.calendar; 导入java...
    编程 发布于2025-06-24
  • 为什么我在Silverlight Linq查询中获得“无法找到查询模式的实现”错误?
    为什么我在Silverlight Linq查询中获得“无法找到查询模式的实现”错误?
    查询模式实现缺失:解决“无法找到”错误在Silverlight应用程序中,尝试使用LINQ建立LINQ连接以错误而实现的数据库”,无法找到查询模式的实现。”当省略LINQ名称空间或查询类型缺少IEnumerable 实现时,通常会发生此错误。 解决问题来验证该类型的质量是至关重要的。在此特定实例中...
    编程 发布于2025-06-24
  • Java中Lambda表达式为何需要“final”或“有效final”变量?
    Java中Lambda表达式为何需要“final”或“有效final”变量?
    Lambda Expressions Require "Final" or "Effectively Final" VariablesThe error message "Variable used in lambda expression shou...
    编程 发布于2025-06-24
  • 在PHP中如何高效检测空数组?
    在PHP中如何高效检测空数组?
    在PHP 中检查一个空数组可以通过各种方法在PHP中确定一个空数组。如果需要验证任何数组元素的存在,则PHP的松散键入允许对数组本身进行直接评估:一种更严格的方法涉及使用count()函数: if(count(count($ playerList)=== 0){ //列表为空。 } 对...
    编程 发布于2025-06-24
  • 如何在Java字符串中有效替换多个子字符串?
    如何在Java字符串中有效替换多个子字符串?
    在java 中有效地替换多个substring,需要在需要替换一个字符串中的多个substring的情况下,很容易求助于重复应用字符串的刺激力量。 However, this can be inefficient for large strings or when working with nu...
    编程 发布于2025-06-24

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

Copyright© 2022 湘ICP备2022001581号-3