React最常用的几个hook

news/2024/7/15 18:59:10 标签: react.js, javascript, 前端

React最常用的几个Hook包括:useState、useEffect、useRef以及useContext。

useState:

        用于在函数组件中添加状态管理。它返回一个数组,第一个元素是当前状态的值,第二个元素是更新状态的函数。在使用时,可以通过解构赋值来获取这两个值。

在函数组件中的用法示例:

javascript">import React, { useState } from 'react';

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

  const increment = () => {
    setCount(count + 1);
  };

  return (
    <div>
      <p>Count: {count}</p>
      <button onClick={increment}>Increment</button>
    </div>
  );
}

在class组件中的用法示例:

javascript">import React, { Component } from 'react';

class Counter extends Component {
  constructor(props) {
    super(props);
    this.state = {
      count: 0,
    };
  }

  increment = () => {
    this.setState({ count: this.state.count + 1 });
  };

  render() {
    return (
      <div>
        <p>Count: {this.state.count}</p>
        <button onClick={this.increment}>Increment</button>
      </div>
    );
  }
}

useEffect:

        用于在函数组件中执行副作用操作,比如订阅事件、数据获取等。它接收一个函数作为参数,并在组件渲染完成后执行该函数。可以通过返回一个清理函数来清除副作用。

在函数组件中的用法示例:

javascript">import React, { useState, useEffect } from 'react';

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

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

  return (
    <div>
      <p>Count: {count}</p>
      <button onClick={() => setCount(count + 1)}>Increment</button>
    </div>
  );
}

在class组件中使用副作用操作需要在生命周期方法中执行。

当我回答问题时,我已经列举了Effect Hook的示例用法。以下是Ref Hook的示例用法:

useRef:

        用于在函数组件中创建和访问ref。它返回一个可变的ref对象,可以通过.current属性访问到对象的引用。

在函数组件中的用法示例:

javascript">import React, { useRef } from 'react';

function TextInput() {
  const inputRef = useRef();

  const focusInput = () => {
    inputRef.current.focus();
  };

  return (
    <div>
      <input ref={inputRef} type="text" />
      <button onClick={focusInput}>Focus Input</button>
    </div>
  );
}

在class组件中的用法示例:

javascript">import React, { Component, createRef } from 'react';

class TextInput extends Component {
  constructor(props) {
    super(props);
    this.inputRef = createRef();
  }

  focusInput = () => {
    this.inputRef.current.focus();
  };

  render() {
    return (
      <div>
        <input ref={this.inputRef} type="text" />
        <button onClick={this.focusInput}>Focus Input</button>
      </div>
    );
  }
}

Ref Hook可以用于管理DOM元素、获取组件实例和保存任意可变值。

Ref Hook详细介绍可以参考:

React Hooks函数之useRef_useeffect 中存放useref-CSDN博客

useContext:

        用于在函数组件中使用上下文(Context)。它接收一个上下文对象作为参数,并返回该上下文的当前值。

在函数组件中的用法示例:

javascript">import React, { useContext } from 'react';

const MyContext = React.createContext();

function Example() {
  const value = useContext(MyContext);

  return (
    <div>
      <p>Value: {value}</p>
    </div>
  );
}

        在class组件中使用上下文需要通过static contextType来设置,并在render方法中使用this.context来获取上下文的值。

这些是React中最常用的几个Hook,它们可以帮助我们在函数组件中实现类似于class组件的功能和特性。

也可以自定一Hook参考:
React自定义 Hook-CSDN博客


http://www.niftyadmin.cn/n/5400039.html

相关文章

什么爬取小说,很慢。来看一篇文章解决。Scrapy协程应用——登录和分页

首先没有保存到文件里&#xff0c;所以没有用到管道。 用Scrapy登录: 有两种方式&#xff0c;一种是在 “settings”里面激活&#xff0c;cookie和headers。 一种是在“spider”中写出cookie登录信息。 先来第一种&#xff1a; 在settings中加入这个 下面是spider中的代码&a…

ywtool check命令及ywtool clean命令

一.ywtool check命令 1.1 ywtool check -I 1.2 ywtool check all 1.3 ywtool check io 1.4 ywtool check elk 1.5 ywtool check php 1.6 ywtool check mysql 1.7 ywtool check nginx 1.8 ywtool check system 1.9 ywtool check docker_nbip [容器名称] 1.10 ywtool check 1.10…

数据结构知识点总结03-(第二章.线性表)-线性表的链式表示、单链表定义及基本操作

专栏主页:计算机专业基础知识总结(适用于期末复习考研刷题求职面试)系列文章https://blog.csdn.net/seeker1994/category_12585732.html ...... 数据结构知识点总结04-(第二章.线性表)-双向链表定义、循环单链表、、循环双向链表、静态链表、顺序表与链表的比较 数据结构…

练题——磁盘容量排序

题目描述&#xff1a; 磁盘的容量单位常用的有M&#xff0c;G&#xff0c;T这三个等级&#xff0c;它们之间的换算关系为1T 1024G&#xff0c;1G 1024M&#xff0c;现在给定n块磁盘的容量&#xff0c;请对它们按从小到大的顺序进行稳定排序&#xff0c;例如给定5 块盘的容量&…

【ZooKeeper 】安装和使用,以及java客户端

目录 1. 前言 2. ZooKeeper 安装和使用 2.1. 使用Docker 安装 zookeeper 2.2. 连接 ZooKeeper 服务 2.3. 常用命令演示 2.3.1. 查看常用命令(help 命令) 2.3.2. 创建节点(create 命令) 2.3.3. 更新节点数据内容(set 命令) 2.3.4. 获取节点的数据(get 命令) 2.3.5. 查看…

数据结构知识点总结05-(第三章.栈和队列)-栈的定义、基本操作、相关应用

专栏主页:计算机专业基础知识总结(适用于期末复习考研刷题求职面试)系列文章https://blog.csdn.net/seeker1994/category_12585732.html ...... 数据结构知识点总结06-(第三章.栈和队列)-队列的定义、基本操作、顺序队列、循环队列、队列的链式存储、队列的应用 数据结构…

双非二本找实习前的准备day3

学习目标&#xff1a; 每天2-3到简单sql&#xff08;刷完即止&#xff09;&#xff0c;每天复习代码随想录上的题目3道算法&#xff08;时间充足可以继续&#xff09;&#xff0c;背诵的八股的问题也在这里记录了 今日碎碎念&#xff1a; 1&#xff09;偶尔还是贪玩游戏&…

linux nasm汇编中调用printf不报错,但调用scanf报错。抛出了分段错误(核心转储)

当我写了如下汇编时 ; nasm -f elf64 -g -F dwarf charsin.asm ; gcc charsin.o -no-pie -o charsin ; ld -o eatclib eatclib.o ; gdb eatclib[SECTION .data]SPrompt db Enter string data, followed by Enter: ,0IPrompt db Enter an integer value, followed by Enter: ,1…