Я использую React для генерации компонентов из массива, который находится в состоянии через хуки. Инициализированный массив работает без проблем, но перестает работать после обновления его состояния:
export function AiShip(props) {
const shipType = props.shipType;
const maxShields = Ships[shipType][Stats.shields];
const maxHull = Ships[shipType][Stats.hull];
const squadId = props.squadId;
const [targetPosition, setTargetPosition] = useState([PSN.FARFRONT]);
const [tokenIds, setTokenIds] = useState([3, 4]); //todo remove initial values
function handleTokenIdChange(value, index) {
const tTokenIds = tokenIds;
tTokenIds.splice(index, 1, value);
setTokenIds(...tTokenIds);
};
return (
<div>
<h1>{Ships[props.shipType][Stats.name]}</h1>
<div className="row">
<div className="col-6">
<ShipStats shipType={shipType}/>
<div className="row ">
<div className="col-4">
<h3>ID:</h3>
</div>
<div className="col-4">
<h3>Shields:</h3>
</div>
<div className="col-4">
<h3>Hull:</h3>
</div>
</div>
{
tokenIds.map( (tokenId) =>
<ShipVariables key={tokenIds.indexOf(tokenId)} maxShields={maxShields} maxHull={maxHull}
tokenIdIndex={tokenIds.indexOf(tokenId)}
handleTokenIdChange={handleTokenIdChange}/>)
}
<br/>
Состояние обновляется с помощью функции handleTokenIdChange. Полученный массив все еще является массивом (я проверял это с помощью функции Array.isArray). Код для запуска обновления состояния приведен здесь:
<div className="col-4">
<Select options={idOptions} onChange={e => props.handleTokenIdChange(e.value, props.tokenIdIndex)}/>
</div>
Я знаю, что обычно проблема заключается в том, что переменная - это не массив, а, например, объект, но здесь это не так. Результатом остается массив, хранящий число. Выбор позволяет пользователю выбрать одно из следующих значений:
const idOptions = [
{value: 0, label: 0},
{value: 1, label: 1},
{value: 2, label: 2},
{value: 3, label: 3},
{value: 4, label: 4},
{value: 5, label: 5},
{value: 6, label: 6},
{value: 7, label: 7},
{value: 8, label: 8},
{value: 9, label: 9},
];
Это стек ошибок:
AiShip.js:49 Uncaught TypeError: tokenIds.map is not a function
at AiShip (AiShip.js:49)
at renderWithHooks (react-dom.development.js:16260)
at updateFunctionComponent (react-dom.development.js:18347)
at beginWork$1 (react-dom.development.js:20176)
at HTMLUnknownElement.callCallback (react-dom.development.js:336)
at Object.invokeGuardedCallbackDev (react-dom.development.js:385)
at invokeGuardedCallback (react-dom.development.js:440)
at beginWork$$1 (react-dom.development.js:25780)
at performUnitOfWork (react-dom.development.js:24698)
at workLoopSync (react-dom.development.js:24671)
at performSyncWorkOnRoot (react-dom.development.js:24270)
at react-dom.development.js:12199
at unstable_runWithPriority (scheduler.development.js:697)
at runWithPriority$2 (react-dom.development.js:12149)
at flushSyncCallbackQueueImpl (react-dom.development.js:12194)
at flushSyncCallbackQueue (react-dom.development.js:12182)
at discreteUpdates$1 (react-dom.development.js:24423)
at discreteUpdates (react-dom.development.js:1438)
at dispatchDiscreteEvent (react-dom.development.js:5881)
```