在 React 中悬停时显示元素或文本
创始人
2025-05-31 16:40:13
0

在 React 中悬停时显示元素或文本:

  1. 在元素上设置 onMouseOveronMouseOut 属性。
  2. 跟踪用户是否将鼠标悬停在状态变量中的元素上。
  3. 根据状态变量有条件地渲染另一个元素。
import {useState} from 'react';const App = () => {const [isHovering, setIsHovering] = useState(false);const handleMouseOver = () => {setIsHovering(true);};const handleMouseOut = () => {setIsHovering(false);};return (
handleMouseOver}onMouseOut={handleMouseOut}>Hover over me
{isHovering && (

Only visible when hovering div

jiyik.com

)}
); };export default App;

React 中悬停时显示元素或文本

代码示例展示了如何在将鼠标悬停在另一个元素上时显示一个元素。

我们在 div 元素上设置了 onMouseOver 属性,因此每次用户将鼠标悬停在该元素上时,都会调用 handleMouseOver 函数。

handleMouseOver}onMouseOut={handleMouseOut}
>Hover over me

当用户将光标移动到元素或其子元素之一时,将触发 mouseover 事件。

在我们的 handleMouseOver 函数中,我们只需将 isHovering 状态变量设置为 true

const handleMouseOver = () => {setIsHovering(true);
};

相反,在我们的 handleMouseOut 函数中,我们将状态变量设置为 false

const handleMouseOut = () => {setIsHovering(false);
};

当用户的光标不再包含在元素或其子元素之一中时,将触发 mouseout 事件。

我们使用逻辑与 && 运算符有条件地呈现另一个 div 元素。

逻辑与 && 运算符如果为假,则返回左侧的值,否则返回右侧的值。

如果状态变量存储假值,逻辑与 && 运算符将返回假,并且不会呈现任何内容。

忽略布尔值、null 和 undefined。 他们根本不渲染。

当用户将鼠标悬停在 div 元素上时:

  1. handleMouseOver 函数被调用。
  2. isHovering 状态变量设置为 true。
  3. 另一个 div 元素被渲染。

相反,当用户将光标移出 div 元素时:

  1. handleMouseOut 函数被调用。
  2. isHovering 状态变量设置为 false。
  3. 另一个 div 元素不再显示。

在 React 中悬停时显示组件

将鼠标悬停在另一个元素上时,可以使用相同的方法来显示组件。

import {useState} from 'react';function Heading() {return (

jiyik.com

); }const App = () => {const [isHovering, setIsHovering] = useState(false);const handleMouseOver = () => {setIsHovering(true);};const handleMouseOut = () => {setIsHovering(false);};return (
handleMouseOver}onMouseOut={handleMouseOut}>Hover over me
{isHovering && }
); };export default App;

在 React 中悬停时显示组件

当我们将鼠标悬停在 div 元素上时,代码示例会显示一个组件。

我们将一个 div 和一个 h2 提取到 Heading 组件中。

每次用户将鼠标悬停在设置了 onMouseOveronMouseOut 属性的 div 上时,都会显示 Heading 组件。

当用户将鼠标移出 div 时,Heading 组件将卸载并且不再呈现。

相关内容

热门资讯

A股玻尿酸巨头出手!2700字... 医美龙头巨子生物“成分争议”风波持续发酵。日前,美妆博主大嘴博士(香港大学化学博士郝宇)发文,质疑巨...
计算机组成原理实验1---运算...     本实验为哈尔滨工业大学计算机组成原理实验,实验内容均为个人完成,...
3 ROS1通讯编程提高(1) 3 ROS1通讯编程提高3.1 使用VS Code编译ROS13.1.1 VS Code的安装和配置...
前端-session、jwt 目录:   (1)session (2&#x...
前端学习第三阶段-第4章 jQ... 4-1 jQuery介绍及常用API导读 01-jQuery入门导读 02-JavaScri...
EL表达式JSTL标签库 EL表达式     EL:Expression Language 表达式语言     ...
数字温湿度传感器DHT11模块... 模块实例https://blog.csdn.net/qq_38393591/article/deta...
【内网安全】 隧道搭建穿透上线... 文章目录内网穿透-Ngrok-入门-上线1、服务端配置:2、客户端连接服务端ÿ...
【Spring Cloud A... 文章目录前言Metadata元数据ClassMetadataSpring中常见的一些元注解Nacos...
React篇-关于React的... 一.简介1.介绍用于构建用户界面的 JavaScript 库2.创建项目(1)手动创建Documen...
win7 Pro 英文版添加中... win7pro x64英文版添加中文语言包1、下载语言包,并解压成lp.cab,复制到...
Android开发-Andro... 01  Android UI 1.1  UI 用户界面(User Interface,...
基于springboot教师人... 基于springboot教师人事档案管理系统【源码+论文】 开发语言:Jav...
编写软件界面的方式 本文重点解决如下问题:编写软件的界面有哪几种方式?通常情形下࿰...
keil调试专题篇 调试的前提是需要连接调试器比如STLINK。 然后点击菜单或者快捷图标均可进入调试模式。 如果前面...
GO语言小锤硬磕十三、数组与切... 数组用来保存一组相同类型的数据,go语言数组也分一维数组和多维数组。 直接上代码看一下...
三级数据库备考--数据库应用系... 1.数据库应用系统设计包括概念设计、逻辑设计、物理设计3个步骤,每个步骤的设计活动按照...
prometheus数据持久化... https://segmentfault.com/a/1190000015710814 promet...
孩子用什么样的灯对眼睛没有伤害... 现代社会高速发展,越来越多的人开始重视身体健康,尤其是很多家长ÿ...
微软Bing GPT支持AI绘... 我想要一张图片:大象、珊瑚、火山、云朵我想要一张图片:亚特兰蒂斯...