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

React常见知识点

1. setCount(10)与setCount(preCount => preCount + 10) 的区别:

import React, { useState } from 'react';
export default function CounterHook() {const [count, setCount] = useState(() => 10);console.log('CounterHook渲染');function handleBtnClick() {// 下面这种只会加10setCount(count + 10);setCount(count + 10);setCount(count + 10);setCount(count + 10);// 下面这种会加到40// setCount((prevCount) => prevCount + 10);// setCount((prevCount) => prevCount + 10);// setCount((prevCount) => prevCount + 10);// setCount((prevCount) => prevCount + 10);}return (<div><h2>当前计数: {count}</h2><button onClick={handleBtnClick}>+10</button></div>);
}

2. 如何在父组件中引用子组件的某个元素? forwardRef

// 父组件
import React, { useEffect, useRef } from 'react';
import Product from './product';
export default function App(props) {const liRef = useRef();useEffect(() => {console.log('ref', liRef.current)})return (<><Product ref={liRef} /></>);
}
// 子组件 - 函数组件
import React from 'react';
import { forwardRef } from 'react';
export default forwardRef((props, ref) => {const getProdInfo = function (e) {console.log(e.target.innerText);};return (<ul onClick={getProdInfo}><li ref={ref}>商品1</li><li>商品2</li></ul>);
});
// 子组件 - class组件
import React, { forwardRef } from 'react';
class Product extends React.Component {constructor(props) {super(props);}getProdInfo = function (e) {console.log(e.target.innerText);};render() {console.log(1, this.props)return (<ul onClick={this.getProdInfo}><li ref={this.props.innerRef}>商品1</li><li>商品2</li></ul>);}
}
export default forwardRef((props, ref) => <Product innerRef={ref} {...props} />);

联想:
ref的作用:

  1. 通过ref操作dom,分为 1.作用在DOM节点上;2作用在组件上(此时为组件的实例);
  2. 用ref引用一个值;参考官网useRef

3. useImperativeHandle

向父组件暴露一个自定义的 ref 句柄。
默认情况下,组件不会将它们的 DOM 节点暴露给父组件。举例来说,如果你想要 MyInput 的父组件 能访问到 <input> DOM 节点,你必须选择使用 forwardRef

import { forwardRef } from 'react';const MyInput = forwardRef(function MyInput(props, ref) {return <input {...props} ref={ref} />;
});

在上方的代码中,MyInput 的 ref 会接收到 DOM 节点。然而,你可以选择暴露一个自定义的值。为了修改被暴露的句柄,在你的顶层组件调用 useImperativeHandle。

相关文章:

React常见知识点

1. setCount(10)与setCount(preCount > preCount 10) 的区别&#xff1a; import React, { useState } from react; export default function CounterHook() {const [count, setCount] useState(() > 10);console.log(CounterHook渲染);function handleBtnClick() {//…...

Vue-router路由

配置路由 相当于SpringMVC的Controller 路径然后&#xff0c;跳转到对应的组件 一键生成前端项目文档...

JVM-CMS

when 堆大小要求为4-8G 原理 初始标记&#xff1a;执行CMS线程->STW&#xff0c;标记GC Root直接关联的对象->低延迟 并发标记&#xff1a;执行CMS线程和业务线程&#xff0c;从GC Root直接关联的对象开始遍历整个对象图 重新标记&#xff1a;执行CMS线程->STW&a…...

无涯教程-Flutter - Dart简介

Dart是一种开源通用编程语言&#xff0c;它最初是由Google开发的&#xff0c; Dart是一种具有C样式语法的面向对象的语言&#xff0c;它支持诸如接口&#xff0c;类之类的编程概念&#xff0c;与其他编程语言不同&#xff0c;Dart不支持数组&#xff0c; Dart集合可用于复制数据…...

如何创建美观的邮件模板并通过qq邮箱的SMTP服务向用户发送

最近在写注册功能的自动发送邮箱告知验证码的功能&#xff0c;无奈根本没有学过前端&#xff0c;只有写Qt的qss基础&#xff0c;只好借助网页设计自己想要的邮箱格式&#xff0c;最终效果如下: 也推销一下自己的项目ShaderLab&#xff0c;可运行ShaderToy上的大部分着色器代码&…...

手机无人直播软件在苹果iOS系统中能使用吗?

在现代社交媒体的时代&#xff0c;直播带货已经成为了一种热门的销售途径。通过直播&#xff0c;人们可以远程分享自己的商品&#xff0c;与观众进行互动&#xff0c;增强沟通和参与感。而如今&#xff0c;手机无人直播软件更是成为了直播带货领域的一项火爆的技术。那么&#…...

创建2个线程并执行(STL/Windows/Linux)

C并发编程入门 目录 STL 写法 #include <thread> #include <iostream> using namespace std;void thread_fun1(void) {cout << "one STL thread 1!" << endl; }void thread_fun2(void) {cout << "one STL thread 2!" <…...

Redis可以干什么

Redis可以做什么&#xff1f; 缓存 Redis作为一款高性能的缓存数据库&#xff0c;能够将常用的数据存储在内存中&#xff0c;以提高读写效率。它支持多种数据结构&#xff0c;如字符串、哈希表、列表、集合等&#xff0c;让你可以根据业务需求选择合适的数据结构进行缓存。 …...

R语言+Meta分析;论文新方向

Meta分析是针对某一科研问题&#xff0c;根据明确的搜索策略、选择筛选文献标准、采用严格的评价方法&#xff0c;对来源不同的研究成果进行收集、合并及定量统计分析的方法&#xff0c;最早出现于“循证医学”&#xff0c;现已广泛应用于农林生态&#xff0c;资源环境等方面。…...

实战系列(二)| MybatisPlus详细介绍,包含代码详解

目录 1. MybatisPlus 的基本功能2. 基本用法3. MybatisPlus 的配置4. MybatisPlus 的实体类、Mapper 接口、Service 类和 Controller 类 MybatisPlus 是一个功能强大的 MyBatis 增强工具&#xff0c;它提供了丰富的特性来简化操作数据库的代码。它主要用于简化 JDBC 操作&#…...

横向对比 npm、pnpm、tnpm、yarn 优缺点

前端工程化是现代Web开发中不可或缺的一环&#xff0c;它的出现极大地提升了前端开发的效率和质量。 在过去&#xff0c;前端开发依赖于手动管理文件和依赖&#xff0c;这导致了许多问题&#xff0c;如版本冲突、依赖混乱和构建繁琐等。而今&#xff0c;随着众多前端工程化工具…...

安防监控/视频汇聚/云存储/AI智能视频融合平台页面新增地图展示功能

AI智能分析网关包含有20多种算法&#xff0c;包括人脸、人体、车辆、车牌、行为分析、烟火、入侵、聚集、安全帽、反光衣等等&#xff0c;可应用在安全生产、通用园区、智慧食安、智慧城管、智慧煤矿等场景中。将网关硬件结合我们的视频汇聚/安防监控/视频融合平台EasyCVR一起使…...

机器人中的数值优化(九)——拟牛顿方法(下)、BB方法

本系列文章主要是我在学习《数值优化》过程中的一些笔记和相关思考&#xff0c;主要的学习资料是深蓝学院的课程《机器人中的数值优化》和高立编著的《数值最优化方法》等&#xff0c;本系列文章篇数较多&#xff0c;不定期更新&#xff0c;上半部分介绍无约束优化&#xff0c;…...

java 从resource下载excel打不开

GetMapping("/download/template")public void template(HttpServletResponse response) throws IOException {ServletOutputStream outputStream response.getOutputStream();InputStream inputStream null;try {//从resource获取excel文件流inputStream getClas…...

NS2安装及入门实例——(ns2.35 / Ubuntu20.04)

文章目录 一、ns2安装1、更新系统源2、准备工作3、下载安装包4、安装5、问题① 问题1② 问题2③ 问题3 6、安装成功7、环境配置 二、nam安装1、安装2、问题 三、实例 一、ns2安装 1、更新系统源 sudo apt-get update sudo apt-get upgrade2、准备工作 sudo apt-get install …...

平面设计的三大基本元素 优漫动游

平面设计需要美术基础&#xff0c;有美术基础的新人往往能更快完成平面设计岗的转行&#xff0c;在专业培训机构内讲师授课时也会从平面设计的基础——三大基本元素开始。今天就跟大家具体介绍一下平面设计的三大基本元素&#xff0c;让大家知道到底都有哪些。 平面设计的三…...

【电子取证篇】汽车取证检验标准

【电子取证篇】汽车取证检验标准 汽车取证鉴定可能涉及的测试/测量方法—【蘇小沐】 GA/T 976-2012《电子数据法庭科学鉴定通用方法》&#xff1b; GA/T 1998-2022《汽车车载电子数据提取技术规范》&#xff1b; GA/T 1999.2-2022《道路交通事故车辆速度鉴定方法 第2部分&…...

【元宇宙】游戏应用商城对元宇宙的影响

游戏行业不仅是创意设计原则的信息源&#xff0c;还是构建“下一代互联网”的基础技术。它也是元宇宙的经济活动先例。 究竟为什么会认为应用商城设置的30%佣金将导致元宇宙“无法实现”呢&#xff1f;有三个核心原因。首先&#xff0c;应用商城阻止了企业对元宇宙的投资&…...

win10-docker-mysql镜像安装运行基础

win10-docker-mysql镜像安装运行基础 文章目录 win10-docker-mysql镜像安装运行基础一、搜索可用镜像1.1 查询mysql镜像1.2 确定镜像版本号 二、运行mysql容器2.1 进入mysql2.2 测试mysql是否正常 三、将mysql数据存储目录映射到宿主机做持久化 一、搜索可用镜像 1.1 查询mysq…...

VirtualBox7+Ubuntu22集群规划

1. 目的: 新入手了一台小主机&#xff08;8核 / Intel(R) Xeon(R) W-10885M CPU 2.40GHz 2.40 GHz, 16vCpu / 64G RAM / 系统类型 64 位操作系统, 基于 x64 的处理器&#xff09;&#xff0c;原装了一套Win11专业版&#xff0c;打算用VirtualBox 虚拟一个集群。 2. …...

微信小程序登录后,商品列表加载慢?从拦截器优化到Redis缓存,一套组合拳提升用户体验

微信小程序登录后商品列表加载慢&#xff1f;全链路性能优化实战 每次打开小程序&#xff0c;看着那个转不停的加载图标&#xff0c;用户的手指是不是已经开始不耐烦地敲击屏幕了&#xff1f;作为开发者&#xff0c;我们最不愿看到的就是精心设计的界面因为性能问题而失去用户耐…...

Leather Dress Collection 构建MCP智能体:实现与外部工具和API的自主交互

Leather Dress Collection 构建MCP智能体&#xff1a;实现与外部工具和API的自主交互 你有没有想过&#xff0c;让一个AI助手不仅能和你聊天&#xff0c;还能在你问“北京今天天气如何&#xff0c;并换算成华氏度”时&#xff0c;自己默默地去查天气、做换算&#xff0c;然后把…...

AI绘画不求人:Neeshck-Z-lmage_LYX_v2本地化部署与使用指南

AI绘画不求人&#xff1a;Neeshck-Z-lmage_LYX_v2本地化部署与使用指南 1. 工具概览&#xff1a;你的私人AI画师 想象一下&#xff0c;你有一个随时待命的数字画家&#xff0c;只需要输入文字描述&#xff0c;就能在几分钟内为你创作出精美的画作。Neeshck-Z-lmage_LYX_v2正是…...

vLLM-v0.17.1安全加固指南:防止提示词注入与滥用

vLLM-v0.17.1安全加固指南&#xff1a;防止提示词注入与滥用 1. 为什么需要安全加固 当你把vLLM服务公开部署到生产环境时&#xff0c;安全防护就不再是可选项。最近我们遇到一个真实案例&#xff1a;某企业未配置任何防护措施的大模型API&#xff0c;上线3天后就被恶意用户通…...

Android AudioManager实战:手把手教你搞定蓝牙耳机与有线耳机的音频切换(附完整代码)

Android音频设备切换实战&#xff1a;从蓝牙耳机到有线耳机的智能路由控制 音乐播放到一半&#xff0c;蓝牙耳机突然没电了&#xff1b;会议演示时&#xff0c;插入有线耳机却希望保持扬声器外放——这些场景对Android开发者来说再熟悉不过。音频路由管理看似简单&#xff0c;实…...

虚拟机、模拟器多开玩家的噩梦:浅谈Win11下USBPcap.sys与其他内核驱动的‘兼容性战争’

Win11多开环境下的内核驱动冲突&#xff1a;从USBPcap看系统稳定性治理 如果你是一名需要在Windows 11上同时运行多个虚拟化工具&#xff08;如VirtualBox、VMware&#xff09;和安卓模拟器&#xff08;雷电、MuMu&#xff09;的高级用户或开发者&#xff0c;那么你可能已经经历…...

lift off工艺中电子束蒸发镀膜的优势与磁控溅射的局限性对比

1. 电子束蒸发与磁控溅射的基本原理对比 在半导体制造领域&#xff0c;lift off工艺是一种常用的图形化金属层制备方法。简单来说&#xff0c;就是先在晶圆表面涂覆光刻胶并曝光显影形成图案&#xff0c;然后沉积金属薄膜&#xff0c;最后通过化学溶剂剥离光刻胶及附着在其上的…...

OpenClaw隐私方案:Qwen2.5-VL-7B本地处理医疗影像数据

OpenClaw隐私方案&#xff1a;Qwen2.5-VL-7B本地处理医疗影像数据 1. 为什么医疗影像需要本地化处理 去年我在帮一家牙科诊所设计AI辅助诊断系统时&#xff0c;遇到了一个棘手问题&#xff1a;他们的X光片包含患者面部特征和牙科记录&#xff0c;直接上传到公有云存在隐私风险…...

Delphi FMX实战:如何优化电商App图片加载性能(附GYListView高效缓存方案)

Delphi FMX电商App图片加载性能优化实战指南 电商类App的核心体验往往取决于商品图片的加载速度和流畅度。当用户快速滑动浏览上百件商品时&#xff0c;任何卡顿或延迟都会直接影响转化率。作为跨平台开发框架&#xff0c;Delphi FMX虽然提供了强大的UI构建能力&#xff0c;但在…...

树莓派实战指南:从零搭建DHT11温湿度监测系统

1. 认识你的硬件伙伴&#xff1a;DHT11与树莓派 第一次拿到DHT11温湿度传感器时&#xff0c;我盯着这个比指甲盖还小的模块看了半天——就这么个小东西能测量环境数据&#xff1f;后来实测发现它虽然精度不如实验室设备&#xff0c;但家用完全够用。DHT11通过单总线协议通信&am…...