第二次单击后获得(取消)选中React复选框

时间:2019-07-14 13:14:05

标签: javascript html reactjs checkbox checkboxlist

以下是react组件的一部分,其中列出了动态复选框:

   <div className="pb-4">
       <p>Choose the task owner(s):</p>
       {
           peerIds.map(id => {
               if (currentUserId != id)
                   return (
                       <label className="checkbox-inline mr-3">
                           <input onChange={onChange_TaskOwner}
                               type="checkbox"
                               name="taskowner"
                               checked={st_taskOwnersId.filter(function (item) {return (item == id)}).length > 0}
                               value={peers[id].id} />
                           <span>{peers[id].fullName}</span>
                       </label>

                   )
           })
       }
       <div style={{ clear: 'both' }}></div>
   </div>

在上面的代码中,如果当前ID已在名为checked的挂钩状态对象中,我将st_taskOwnersId设置为false / true。

我使用hook存储选中项的ID,如下所示。 onChange_TaskOwner函数根据st_taskOwnersIdchecked来更新unchecked

const [st_taskOwnersId, set_taskOwnersId] = useState([] as any);

const onChange_TaskOwner = (event) => {
    event.preventDefault();
    if (event.target.checked)
        set_taskOwnersId([...st_taskOwnersId, event.target.value]);
    else
        set_taskOwnersId(st_taskOwnersId.filter(function (item) {
            return (item != event.target.value);
        }));
}

代码运行无错误。唯一的问题是我必须单击两次以选中/取消选中复选框。我不知道为什么会这样。有帮助吗?

1 个答案:

答案 0 :(得分:1)

我认为问题出在onChange_TaskOwner函数上。您应该删除event.preventDefault();呼叫。

我试图在此codepen上重现您的组件,但没有event.preventDefault();正常工作,如果您添加它,就会开始发生相同类型的错误。