值得一看
广告
彩虹云商城
广告

热门广告位

React 中使用 useState 实现多个按钮的动态切换

react 中使用 usestate 实现多个按钮的动态切换

本文旨在讲解如何使用 React 的 useState hook 实现多个按钮的动态切换,即点击一个按钮时显示其对应的提示信息,同时关闭其他按钮的提示信息。通过示例代码,我们将展示如何维护一个状态来跟踪当前选中的按钮,并根据该状态动态渲染提示信息。

在 React 中,动态切换多个按钮的状态并显示对应的提示信息,可以使用 useState hook 来管理当前选中的按钮。以下是一个详细的步骤和示例代码:

1. 初始化状态:

首先,使用 useState hook 创建一个状态变量 selectedBtn,用于存储当前选中的按钮的标识符。初始值可以设置为空字符串 “”,表示默认没有按钮被选中。

import { useState } from "react";
function App() {
const [selectedBtn, setSelectedBtn] = useState("");
// ...
}

2. 定义按钮列表:

创建一个按钮标识符的数组,例如:

const faqTipBtns = ["faqBtn1", "faqBtn2", "faqBtn3"];

3. 渲染按钮:

使用 map 方法遍历按钮数组,为每个按钮创建一个 JSX 元素。在每个按钮的 onClick 事件处理函数中,调用 setSelectedBtn 函数,将当前按钮的标识符设置为 selectedBtn 的值。

悦灵犀AI

悦灵犀AI

一个集AI绘画、问答、创作于一体的一站式AI工具平台

悦灵犀AI67

查看详情
悦灵犀AI

{faqTipBtns.map((button) => (
<div key={button}>
<button onClick={() => setSelectedBtn(button)}>{button}</button>
</div>
))}

注意:添加 key 属性,这是 React 渲染列表的推荐做法,提高渲染效率。

4. 渲染提示信息:

在每个按钮下方,根据 selectedBtn 的值,有条件地渲染提示信息。如果 selectedBtn 的值与当前按钮的标识符相同,则显示提示信息;否则,不显示。

{faqTipBtns.map((button) => (
<div key={button}>
{selectedBtn === button ? <div> Tooltip {button}</div> : <div />}
<button onClick={() => setSelectedBtn(button)}>{button}</button>
</div>
))}

完整示例代码:

import "./styles.css";
import { useState } from "react";
export default function App() {
const [selectedBtn, setSelectedBtn] = useState("");
const faqTipBtns = ["faqBtn1", "faqBtn2", "faqBtn3"];
return (
<div className="App">
<h1>show Tooltip that related with his button</h1>
{faqTipBtns.map((button) => (
<div key={button}>
{selectedBtn === button ? <div> Tooltip {button}</div> : <div />}
<button onClick={() => setSelectedBtn(button)}>{button}</button>
</div>
))}
</div>
);
}

注意事项:

  • 状态提升: 如果按钮和提示信息不在同一个组件中,需要将 selectedBtn 状态提升到它们的共同父组件中,并通过 props 传递给子组件。
  • 性能优化: 如果按钮数量很多,可以考虑使用 useMemo hook 来缓存提示信息,避免重复渲染。
  • 唯一 Key: 在使用 map 函数渲染列表时,确保每个元素都有唯一的 key 属性,以便 React 能够高效地更新 DOM。

总结:

通过使用 useState hook 和条件渲染,可以轻松实现多个按钮的动态切换和提示信息的显示。关键在于维护一个状态来跟踪当前选中的按钮,并根据该状态动态渲染 UI。希望本教程能够帮助你理解如何在 React 中实现这一功能。

相关标签:

css react js app 标识符 字符串 map 事件 dom 性能优化 ui
温馨提示: 本文最后更新于2025-09-04 22:42:21,某些文章具有时效性,若有错误或已失效,请在下方留言或联系在线客服
文章版权声明 1 本网站名称: 创客网
2 本站永久网址:https://new.ie310.com
1 本文采用非商业性使用-相同方式共享 4.0 国际许可协议[CC BY-NC-SA]进行授权
2 本站所有内容仅供参考,分享出来是为了可以给大家提供新的思路。
3 互联网转载资源会有一些其他联系方式,请大家不要盲目相信,被骗本站概不负责!
4 本网站只做项目揭秘,无法一对一教学指导,每篇文章内都含项目全套的教程讲解,请仔细阅读。
5 本站分享的所有平台仅供展示,本站不对平台真实性负责,站长建议大家自己根据项目关键词自己选择平台。
6 因为文章发布时间和您阅读文章时间存在时间差,所以有些项目红利期可能已经过了,能不能赚钱需要自己判断。
7 本网站仅做资源分享,不做任何收益保障,创业公司上收费几百上千的项目我免费分享出来的,希望大家可以认真学习。
8 本站所有资料均来自互联网公开分享,并不代表本站立场,如不慎侵犯到您的版权利益,请联系79283999@qq.com删除。

本站资料仅供学习交流使用请勿商业运营,严禁从事违法,侵权等任何非法活动,否则后果自负!
THE END
喜欢就支持一下吧
点赞11赞赏 分享
评论 抢沙发

请登录后发表评论

    暂无评论内容