我有一个代码来切换表格中的所有复选框,如下所示:
const tblData = dummyData;
const [ allToggled, setAllToggled ] = useState(false);
const [ toggled, setToggled ] = useState(false);
const handleToggleAll = allToggled => {
let selectAll = !allToggled;
setAllToggled(selectAll);
let toggledCopy = [];
tblData.forEach(function (e, index) {
toggledCopy.push(selectAll);
});
setToggled(toggledCopy);
}
const handleToggle = index => {
let toggledCopy = toggled;
setToggled[index] = toggled[index];
if( toggledCopy[index] === false ){
setAllToggled(false);
}
}
和反应表部分:
Header: state => (
<input
type="checkbox"
checked={allToggled}
onChange={() => handleToggleAll(allToggled)}
/>
),
Cell: row => (
<input
type="checkbox"
checked={toggled[row.index]}
/>
)
在我使用之前一切正常handleToggleAll
。它将所有复选框切换为true
状态,但是当我取消选中时,handleToggleAll
我无法将它们设置回true
任何单个复选框都不能被选中。