olegpavlov897
@olegpavlov897
Люблю писать и видеть как оно заработало )))

Как добавить в setState (react-typescript hooks) массив?

type CardAutoNowType = {
id: number,
title: string,
volume: string,
pack: string,
fuel: string,
release: string,
kpp: string,
price: string,
availability: number,
img?: string,
img_1?: string | undefined
img_2?: string | undefined
img_3?: string | undefined
img_4?: string | undefined
model: string
}

Есть const [arrResult, setArrResult] = useState<[]>([])

Пытаюсь засунуть массив обьектов

let model: CardAutoNowType[] = []
model = arrCard.filter((elem: { model: string }) => elem.model === elemModel)
setArrResult(...arrResult, model)

Выводит ошибку :

Аргумент типа "CardAutoNowType[]" нельзя назначить параметру типа "SetStateAction<[]>".
Тип "CardAutoNowType[]" не может быть назначен для типа "(prevState: []) => []".
Тип "CardAutoNowType[]" не предоставляет соответствия для сигнатуры "(prevState: []): []".
  • Вопрос задан
  • 326 просмотров
Пригласить эксперта
Ответы на вопрос 1
@ArgeoMer
Вы useState типизировали под пустой массив.
Правильно:
const [arrResult, setArrResult] = useState<CardAutoNowType[]>([])

Тип CardAutoNowType[] предполагает наличие либо пустого массива либо массива только с элементами типа CardAutoNowType
Ответ написан
Комментировать
Ваш ответ на вопрос

Войдите, чтобы написать ответ

Похожие вопросы
22 нояб. 2024, в 08:04
1 руб./за проект
22 нояб. 2024, в 06:06
1500 руб./в час
22 нояб. 2024, в 06:04
1 руб./за проект