当前位置: 首页 > article >正文

React Hooks使用方法:useState,useRef,useEffect,useReducer,useContext用法实战案例

 react hooks介绍,包括了state,ref,effect,reducer,context等常见hooks,也包括forwardRef和createContext用法,下面看代码吧,我用的是js写的。每个hook都做了个案例。

// 使用state来实现点击加减
import { useState} from 'react'
const UseStateTest=()=> {const [count, setCount] = useState(0)const increment=()=>{console.log('+')setCount(prev=>prev+1)}const decrement=()=>{console.log('-')setCount(prev=>prev-1)}return (<><div><p>count的数值为:{count}</p><button onClick={increment}>点击加一</button><button onClick={decrement}>点击减一</button></div></>)
}export default UseStateTest
// 这里是state和ref配合使用赋予输入框的值
import { useState,useRef } from 'react'const UseRefTest=()=> {const [inputValue,setInputValue]=useState('')const iptRef = useRef()const change=()=>{let value=iptRef.current.valueconsole.log(value)setInputValue(value)}return (<><div><input value={inputValue} ref={iptRef} onChange={change}/></div></>)
}export default UseRefTest
// 这里son子组件配合father使用,达到子组件传值到父组件并且让父组件调用和修改
import { useState,useRef } from 'react'
import SonUseRefTest from './SonUseRefTest'
const FatherUseRefTest=()=> {const sonRef = useRef();const [SonRefItem,setSonRefItem]=useState(null)const onshow=()=>{setSonRefItem(JSON.stringify(sonRef.current))}const onreset=()=>{sonRef.current?.setInputValue('')}return (<><div><h1>父组件</h1><h2>{SonRefItem}</h2><button onClick={onshow}>点击显示</button><button onClick={onreset}>点击重置</button><hr/><SonUseRefTest ref={sonRef}/></div></>)
}export default FatherUseRefTest// 这里son子组件配合father使用,达到子组件传值到父组件并且让父组件调用和修改
import React,{ useState,useRef,useImperativeHandle } from 'react'const SonUseRefTest=React.forwardRef((props,ref)=> {const [inputValue,setInputValue]=useState('')const change=(e)=>{setInputValue(e.target.value)}useImperativeHandle(ref,()=>({inputValue,setInputValue}))return (<><div><h2>子组件</h2><input value={inputValue} onChange={change}/></div></>)
})export default SonUseRefTest

import { useState , useEffect , useReducer} from 'react'
import SonUseReduceTest from './SonUseReduceTest'
const defaultState={count:0,name:'李四',flag:true
}
const reducer=(state=defaultState,action)=>{switch(action.type){case 'change_name':console.log(action)return {...state,name:action.name}case 'change_flag':console.log(action)return {...state,flag:action.flag}case 'son_change_name':console.log(action)return {...state,name:action.name}case 'son_change_flag':console.log(action)return {...state,flag:action.flag}  default : return state;}}
const UseReduceTest=()=> {const [state,dispatch]=useReducer(reducer,defaultState)const changeName=()=>{dispatch({type:'change_name',name:"张三"})}const changeFlag=()=>{dispatch({type:'change_flag',flag:!state.flag})}return (<><div><div>当前name为{String(state.name)}</div><br/><button onClick={changeName}>点击修改name</button><br/><div>当前flag为{String(state.flag)}</div><br/><button onClick={changeFlag}>点击修改flag</button><br/><SonUseReduceTest {...state} dispatch={dispatch}/></div></>)
}export default UseReduceTestimport { useState , useEffect} from 'react'
const SonUseReduceTest=(props)=> {const {dispatch,...state}=propsconst changeName=()=>{dispatch({type:'son_change_name',name:"王五"})}const changeFlag=()=>{dispatch({type:'son_change_flag',flag:!state.flag})}return (<><div><br/><br/><div>SonUseReduceTest</div><div>当前名字为{state.name}</div><button onClick={changeName}>点击修改name</button><div>当前flag为{JSON.stringify(state.flag)}</div><button onClick={changeFlag}>点击修改flag</button></div></>)
}export default SonUseReduceTest

import { useState , useEffect} from 'react'
const UseEffectTest=()=> {const [current, setCurrent] = useState(0)const [pagesize, setPagesize] = useState(10)const [totle] = useState(0)const [count, setCount] = useState(0)const [flag, setFlag] = useState(true)const add=(num)=>{setCount(prev=>prev+num)}const showHide=()=>{setFlag(prev=>!prev)}// 不传递依赖项,就是状态有更新就重新执行effect函数// useEffect(()=>{// 	console.log('刷新了组件!!!')// })// 传递依赖项,只有对应state改变时才会执行effect函数//  useEffect(()=>{// 	console.log('刷新了组件!!!')// },[count])// 传递依赖项为空,只有第一次渲染完成时才会执行effect函数useEffect(()=>{console.log('刷新了组件!!!')},[])return (<><div><div>当前count的为:{count}</div><button onClick={()=>add(1)}>点击+1</button><button onClick={()=>add(-1)}>点击-1</button><br/><button onClick={showHide}>点击修改Flag</button><div>当前flag的为:{String(flag)}</div></div></>)
}export default UseEffectTest
//定义一个context文件,单独存放在src下即为src->context-context,里面具体代码为如下:
import React ,{useState,useRef,useEffect,useContext} from 'react'
const FirstContext=React.createContext()export {FirstContext
}// 非嵌入式context
import React ,{ useState , useEffect , useContext} from 'react'
import LevelB from './LevelB'
import {FirstContext} from '../../../context/context'
const LevelA=()=>{const [count,setCount]=useState(0)const add=()=>{setCount(prev=>prev+1)}return (<><FirstContext.Provider value={{count,setCount}}><div>这是LevelA组件的count值为:{count}</div><button onClick={add}>+1</button><hr/><br/><LevelB/></FirstContext.Provider></>)
}export default LevelAimport React ,{ useState , useEffect , useContext} from 'react'
import LevelC from './LevelC'
const LevelB=()=>{return (<div><div>这是LevelB组件</div><hr/><br/><LevelC/></div>)
}export default LevelBimport React ,{ useState , useEffect , useContext} from 'react'
import {FirstContext} from '../../../context/context'
const LevelC=()=>{const {count,setCount}=useContext(FirstContext)const cadd=()=>{setCount(prev=>prev+1)}return (<><div>这是LevelC组件</div><div>{count}</div><button onClick={cadd}>+1</button></>)
}
export default LevelC

相关文章:

React Hooks使用方法:useState,useRef,useEffect,useReducer,useContext用法实战案例

react hooks介绍&#xff0c;包括了state&#xff0c;ref&#xff0c;effect&#xff0c;reducer&#xff0c;context等常见hooks&#xff0c;也包括forwardRef和createContext用法&#xff0c;下面看代码吧&#xff0c;我用的是js写的。每个hook都做了个案例。 // 使用state来…...

线程池详解:在SpringBoot中的最佳实践

线程池详解&#xff1a;在SpringBoot中的最佳实践 引言 在Java并发编程中&#xff0c;线程池是一种非常重要的资源管理工具&#xff0c;它允许我们在应用程序中有效地管理和重用线程&#xff0c;从而提高性能并降低资源消耗。特别是在SpringBoot等企业级应用中&#xff0c;正…...

扩展卡尔曼滤波

1.非线性系统的线性化 标准卡尔曼滤波 适用于线性化系统&#xff0c;扩展卡尔曼滤波 则扩展到了非线性系统&#xff0c;核心原理就是将非线性系统线性化&#xff0c;主要用的的知识点是 泰勒展开&#xff08;我另外一篇文章的链接&#xff09;&#xff0c;如下是泰勒展开的公式…...

AI作为学术评审专家有哪些优缺点?

大家好这里是AIWritePaper官方账号&#xff0c;官网&#x1f449;AIWritePaper论文完成初稿之后&#xff0c;一般情况下&#xff0c;宝子们还需要找专家给我们提出评审意见。找专家评审其实并不容易&#xff0c;即使对老师来说&#xff0c;找人评审论文也是一件苦活。我们这个时…...

微信小程序登录和获取手机号

目录 准备工作 实现流程 实现代码 公共部分 通过code获取openid等信息 解密手机号 扩展 不借助工具类实现解密 借助工具类获取access_token 准备工作 需要小程序账号&#xff08;可以去微信公众平台创建一个测试号或者正式号&#xff09; appid&#xff1a;小程序id …...

4.Matplotlib:基础绘图

一 直方图 1.如何构建直方图 将值的范围分段&#xff0c;将整个值的范围分成一系列间隔&#xff0c;然后计算每个间隔中有多少值。 2.直方图的适用场景 一般用横轴表示数据类型&#xff0c;纵轴表示分布情况。 直方图可以用于识别数据的分布模式和异常值&#xff0c;以及观察数…...

与Aspose.pdf类似的jar库分享

如果你在寻找类似于 Aspose.PDF 的 JAR 库&#xff0c;这些库通常用于处理 PDF 文档的创建、编辑、转换、合并等功能。以下是一些类似的 Java 库&#xff0c;它们提供 PDF 处理的功能&#xff0c;其中一些是收费的&#xff0c;但也有开源选项&#xff1a; 1. iText (iText PDF…...

VSCode 市场发现恶意扩展正在传播勒索软件!

在VSCode 市场中发现了两个隐藏着勒索软件的恶意扩展。其中一个于去年 10 月出现在微软商店&#xff0c;但很长时间没有引起注意。 这些是扩展ahban.shiba 和 ahban.cychelloworld&#xff0c;目前已从商店中删除。 此外&#xff0c;ahban.cychelloworld 扩展于 2024 年 10 月…...

工作流引擎Flowable介绍及SpringBoot整合使用实例

Flowable简介 Flowable 是一个轻量级的业务流程管理&#xff08;BPM&#xff09;和工作流引擎&#xff0c;基于 Activiti 项目发展而来&#xff0c;专注于提供高性能、可扩展的工作流解决方案。它主要用于企业级应用中的流程自动化、任务管理和审批流等场景。 Flowable 的核心…...

K8s证书--运维之最佳选择(K8s Certificate - the best Choice for Operation and Maintenance)

K8s证书--运维之最佳选择 No -Number- 01 一个月速通CKA 为了速通CKA&#xff0c;主要办了两件事情 1. 在官方的Killercoda上&#xff0c;练习CKA的题目。把命令敲熟悉。 // https://killercoda.com/killer-shell-ckad 2. 使用K3s在多台虚拟机上快速搭建了K8s集群&…...

MySQL 8.0.41源码目录深度解析:探索数据库内核的架构蓝图

文章目录 MySQL 8.0.41源码目录深度解析&#xff1a;探索数据库内核的架构蓝图一、MySQL 8.0.41 目录结构总览1.1 安装目录核心子目录1.2 数据目录关键组件 二、核心源码模块剖析2.1 SQL 引擎核心&#xff08;sql / 目录&#xff09;2.1.1 核心组件2.1.2 架构亮点 2.2 存储引擎…...

Leaflet.js+leaflet.heat实现热力图

Leaflet热力图 #mermaid-svg-I1zXN0OrNCBGKEWy {font-family:"trebuchet ms",verdana,arial,sans-serif;font-size:16px;fill:#333;}#mermaid-svg-I1zXN0OrNCBGKEWy .error-icon{fill:#552222;}#mermaid-svg-I1zXN0OrNCBGKEWy .error-text{fill:#552222;stroke:#5522…...

通过git文件查看大模型下载链接的解决方案

大家好,我是爱编程的喵喵。双985硕士毕业,现担任全栈工程师一职,热衷于将数据思维应用到工作与生活中。从事机器学习以及相关的前后端开发工作。曾在阿里云、科大讯飞、CCF等比赛获得多次Top名次。现为CSDN博客专家、人工智能领域优质创作者。喜欢通过博客创作的方式对所学的…...

多源最短路:Floyd算法の暴力美学

多源最短路求解的是图中的任意两个节点之间的最短路。 前文我们已经讲过单源最短路&#xff0c;我们完全可以做n次单源最短路算法&#xff0c;求出任意两节点的最短距离。最快的堆优化版的 dijkstra 算法的时间复杂度为o&#xff08;m * logm&#xff09;&#xff0c;枚举n次时…...

初教六双机一飞冲天动作要领

初教六双机一飞冲天动作要领 初教六双机“一飞冲天”是典型的垂直爬升特技动作&#xff0c;要求双机以近乎垂直的姿态同步高速爬升&#xff0c;展现飞机的动力性能与编队协同能力。以下是该动作的详细技术解析与执行要点&#xff1a; 一、动作定义与特点 基本形态 双机以相同速…...

qtcore在docker容器中运行

FROM ubuntu # 设置时区环境变量 ENV TZAsia/Shanghai RUN echo "${TZ}" > /etc/timezone \ && ln -sf /usr/share/zoneinfo/${TZ} /etc/localtime \ && apt update \ && apt install -y tzdata \ && rm -rf /var/lib/apt…...

simpleITK - Setup - Pythonic Syntactic Sugar

Pythonic Syntactic Sugar Image Basics Notebook 非常简单&#xff0c;与 ITK 的 C 接口非常接近。 Sugar非常棒&#xff0c;它能让你精力充沛&#xff0c;更快地完成任务&#xff01;SimpleITK 也应用了大量Sugar来帮助更快地完成任务。 %matplotlib inline import matplo…...

【leetcode hot 100 215】数组中的第K个最大元素

解法一&#xff1a;维护最大最小值 -> 堆 -> k个元素的最小值堆 class Solution {public int findKthLargest(int[] nums, int k) {// 维护最大最小值 -> 堆 -> k个元素的最小值堆PriorityQueue<Integer> heap new PriorityQueue<>((n1, n2) -> n…...

下载vmware17

我用VMware10安装ubuntu24&#xff0c;死活不能成功&#xff0c;要么突然退出&#xff0c;要么装着装着&#xff0c;眼看完成&#xff0c;居然卡住不动&#xff0c;一查日志&#xff0c;提示光盘读取失败&#xff08;用的ISO文件&#xff0c;居然装模作样的说光驱读取失败&…...

德昂观点:如何看待MicroStrategy改名为Strategy?

2025年2月&#xff0c;纳斯达克上市公司MicroStrategy&#xff08;股票代码&#xff1a;MSTR&#xff09;宣布更名为“Strategy”&#xff0c;并同步启用全新品牌标识与橙色主视觉。这不仅是品牌形象的更新&#xff0c;更是公司战略方向的明确宣示。德昂作为MSTR中国区BI合作伙…...

嵌入式八股RTOS与Linux---网络系统篇

前言 关于计网的什么TCP三次握手 几层模型啊TCP报文啥的不在这里讲,会单独分成一个计算机网络模块   这里主要介绍介绍lwip和socket FreeRTOS下的网络接口–移植LWIP 实际上FreeRTOS并不自带网络接口,我们一般会通过移植lwip协议栈让FreeRTOS可以通过网络接口收发数据,具体可…...

Django 生成 ssl 安全证书,切换 https、wss协议(daphne 、nginx)

Django 普通 http 协议不够安全&#xff0c;无法支持连接本地摄像头&#xff08;虽然在本地 localhost 上能连&#xff09;&#xff0c;此时需要切换成 https 协议&#xff08;先提个醒&#xff0c;我这个方法最后失败了&#xff0c;不过对您应该也有帮助&#xff09; 目录 配置…...

告别Win10强制更新:永久关闭系统更新指南

你是否厌倦了Win10在开关机时的强制自动更新&#xff1f;无论你是在赶时间还是专注于工作&#xff0c;那突如其来的更新提示总是让人不胜其烦。屏幕上那句“正在更新&#xff0c;请勿关闭电源”的提示&#xff0c;仿佛是对你无奈的嘲笑。别担心&#xff0c;今天我将教你如何永久…...

【django】2-1 (django配置) 应用配置、中间件配置、模板配置

文章目录 1 基本设置2 应用配置2.1 django核心应用2.2 常用第三方应用 3 中间件3.1 默认使用的中间件3.2 其它内置中间件3.3 第三方中间件3.4 中间件的执行顺序 4 模板引擎配置4.1 配置字典的键4.2 上下文处理器 创建django项目后&#xff0c;会自动生成初始的项目文件如下&…...

nginx-rtmp-module之ngx_rtmp.c代码详解

1. ngx_rtmp.c — RTMP模块的主逻辑实现 这个文件是 RTMP 模块的核心&#xff0c;包含了 RTMP 协议模块的初始化、配置解析和服务端口的管理等功能。它的主要职责是处理 RTMP 配置、初始化模块、配置事件、初始化 RTMP 端口等。 主要功能和逻辑&#xff1a; 模块初始化 (ngx_…...

罗杰斯特回归

定义 逻辑回归其实就是原来的线性回归加了激活函数&#xff0c;这个函数其实就是sigmoid函数&#xff0c;把一个回归的连续数值压缩到了0到1的空间&#xff0c;其实只要有函数能够满足把数值压缩到0,1之间就可以&#xff08;因为0到1之间的数值就是概率值&#xff09; 对于分类…...

Android 10.0 SystemUI状态栏去掉刘海屏功能实现

1.前言 在android10.0的系统rom定制化开发中,在一些产品中,对于带有刘海屏的产品中,会因为 刘海屏导致状态栏能显示图片的位置很小,然后会出现状态栏图标显示为白点的功能, 接下来看下问题怎么解决 2.SystemUI状态栏去掉刘海屏功能实现的核心类 frameworks/base/core/r…...

三维空间中点、线、面的关系

三维空间中点、线、面的关系 点相对于平面的位置关系直线相对于平面的位置关系1.根据三点计算平面方程 //根据3点计算平面方程#include <iostream> #include <cmath> #include <vector>...

【嵌入式学习2】C语言 - VScode环境搭建

目录 ## 语言分类 ## c语言编译器 ## VScode相关配置 ## 语言分类 编译型语言&#xff1a;C&#xff0c;C解释型语言&#xff1a;python&#xff0c;JS ## c语言编译器 分类GCC 系列MinGWCygwinMSVC系列一套编程语言编译器将GCC编译器和GNU Binutils移植到Win32平台下的产物…...

TCP/IP的网络连接设备

TCP/IP层物理层网卡、集线器、中继器数据链路层网桥、交换机网络层路由器传输层网关应用层 1.网桥&#xff1a;网桥主要功能是将一个网络的数据沿通信线路复制到另一个网络中去&#xff0c;可以有效的连接两个局域网 2.网关&#xff1a;网关又称协议转换器&#xff0c;是将两…...