首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >第一次单击不触发onClick,第二次单击按预期操作

第一次单击不触发onClick,第二次单击按预期操作
EN

Stack Overflow用户
提问于 2022-11-21 21:21:03
回答 1查看 29关注 0票数 0

当我按onclick()按钮时,我希望SVG图片改变。但它只适用于第二媒体。

代码语言:javascript
运行
复制
    const [taskList, setTaskList] = useState([]);
    const [indexTask, setIndexTask]=useState({});
    const [statusTask, setStatusTask]=useState(false);


const markComplete = (props)=>{
        let tempList = taskList;
        for(let i=0; i<tempList.length; i++){
            if(indexTask===i){
                tempList[i].status = props;
            }     
        }
        setTaskList([...tempList]);
    } 
代码语言:javascript
运行
复制
 {taskList.map((obj,i)=>   
                    <div key={i} className='div-task'>
                        <div className='div-task-container'>
                            <div className='div-task-status'>
                                <div className='div-task-status-complete' onClick={()=>{markComplete(true); setIndexTask(i)}} role={'button'}>
                                <SvgTaskUncomplete statusTask={obj.status} setStatusTask={setStatusTask} ></SvgTaskUncomplete>
                                </div>
                                <div className='div-task-status-uncomplete' onClick={()=>{markComplete(false); setIndexTask(i)}} role={'button'}>
                                <SvgTaskComplete statusTask={obj.status} setStatusTask={setStatusTask}></SvgTaskComplete>
                                </div>

当我按onclick()按钮时,我希望SVG图片改变。但它只适用于第二媒体。首先点击按钮 第二次点击按钮

EN

回答 1

Stack Overflow用户

发布于 2022-11-21 22:24:27

看来,发布的代码可能与indexTask状态过于复杂。

尝试这个直接将index传递给markComplete的版本:

代码语言:javascript
运行
复制
const [taskList, setTaskList] = useState([]);
const [statusTask, setStatusTask]=useState(false);

const markComplete = (status, index) => {
  const tempList = [...taskList];
  tempList[index].status = status;
  setTaskList(tempList);
};
代码语言:javascript
运行
复制
{taskList.map((obj,i)=>   
  <div key={i} className='div-task'>
      <div className='div-task-container'>
          <div className='div-task-status'>
              <div className='div-task-status-complete' onClick={()=>{markComplete(true, i)}} role={'button'}>
              <SvgTaskUncomplete statusTask={obj.status} setStatusTask={setStatusTask} ></SvgTaskUncomplete>
              </div>
              <div className='div-task-status-uncomplete' onClick={()=>{markComplete(false, i)}} role={'button'}>
              <SvgTaskComplete statusTask={obj.status} setStatusTask={setStatusTask}></SvgTaskComplete>
              </div>

张贴的代码是部分的,所以不能测试它,但希望这仍然可以作为参考。

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/74525019

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档