React中为什么点击一个复选框会取消之前的选择?
P粉729198207
P粉729198207 2023-08-13 10:57:24
[React讨论组]
<p>我有多个复选框,当我点击一个复选框然后点击下一个时,前一个复选框会被取消选择,你知道为什么吗?</p> <p>这是我的复选框组件:</p> <pre class="brush:php;toolbar:false;">const Checkbox = ({ key, id, label, checked, name, onChange }:any) =&gt; { return ( &lt;div className="checkbox-wrapper"&gt; &lt;input multiple key={id} id={id} type="checkbox" checked={checked} name={name} onChange={onChange} /&gt; &lt;label htmlFor={id}&gt;{label}&lt;/label&gt; &lt;/div&gt; ) }</pre> <p>这是主要组件的样子,数据存在一个数组中,然后被映射出来,但我不确定为什么它会取消选择前一个复选框,我已经删除了很多其他无用的JSX代码:</p> <pre class="brush:php;toolbar:false;">const checkboxList = [ { id:0, label:"大写", name: "upper", checked:false }, { id:1, label:"小写", name: "lower", checked:false }, { id:2, label:"数字", name: "number", checked:false }, { id:3, label:"符号", name: "symbols", checked:false } ] const PasswordGenerator = () =&gt; { const [data, setData] = useState(checkboxList) const handleChange = (id:number) =&gt; { const updateCheckboxes = checkboxList.map((checkbox) =&gt; checkbox.id === id ? {...checkbox, checked: !checkbox.checked}:checkbox) setData(updateCheckboxes) } return ( &lt;div className="elements"&gt; {data.map((obj) =&gt; { return( &lt;div key={obj.id}&gt; &lt;Checkbox multiple={true} id={obj.id} label = {obj.label} checked= {obj.checked} name= {obj.name} onChange = {() =&gt; handleChange(obj.id)} /&gt; &lt;/div&gt; ) })} &lt;/div&gt; ) }</pre> <p><br /></p>
P粉729198207
P粉729198207

全部回复(1)
P粉662361740

当你更新状态时,你是从原始数组而不是当前状态进行更新的。而不是从原始数组(checkboxList)进行映射,而是从状态的当前值(data)进行映射:

const handleChange = (id:number) => {
  const updateCheckboxes = data.map((checkbox) => 
    checkbox.id === id ? {...checkbox, checked: !checkbox.checked}:checkbox)

  setData(updateCheckboxes)
}
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送
PHP中文网APP
随时随地碎片化学习
PHP中文网抖音号
发现有趣的

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号