如何在 React 列表中只为单个项触发状态变更?

8次阅读

如何在 React 列表中只为单个项触发状态变更?

react 中渲染列表时,若需点击某一项仅显示其关联的按钮(而非全部),应避免使用布尔型全局状态,而改用索引或唯一标识符精准控制单个元素的显隐。

当我们在列表中使用一个布尔状态(如 startconv: Boolean)控制所有按钮的显示/隐藏时,所有项都会同步响应——因为每个

以下是推荐的实现方式(基于数组索引):

import React, { useState } from 'react'; export function App() { const [activeIndex, setActiveIndex] = useState(null); // 初始为 null,表示无激活项 const current = [ { name: 'yaba1', age: 20 }, { name: 'yaba2', age: 23 } ]; const handleClick = (index) => { setActiveIndex(index); // 仅记录被点击项的索引 }; return ( 

{current.map((item, index) => (

handleClick(index)} // 传入当前索引 >

@@##@@

{item.name}

{/* 仅当当前索引等于 activeIndex 时渲染按钮 */} {activeIndex === index && ( )}

))}

text=ZqhQzanResources