Каков правильный тип событий ввода файла?

Я использую Vue и имею простой ввод файла с прослушивателем изменений.

<script setup lang = "ts">
function handleSelectedFiles(event: Event) {
  const fileInputElement = event.target as HTMLInputElement;

  if (!fileInputElement?.files) {
    return;
  }

  // handle files ...
}
</script>

<template>
  <input type = "file" @change = "handleSelectedFiles"/>
</template>

Код работает нормально, но проверка типа завершается с кодом ошибки. я получаю сообщение об ошибке

ошибка TS2322: тип «(событие: событие) => void» не может быть назначен типу «событие».

Какой правильный тип параметра для функции handleSelectedFiles?

В качестве примечания: я просто хочу загрузить некоторые файлы и обработать их, чтобы были лучшие способы чтения выбранных файлов из ввода.


В целях размножения:

  • Создайте новый проект через npm init vue@latest (просто выберите все)
  • Замените файл App.vue содержимым HTML, опубликованным выше.
  • Беги npm run type-check, должно пройти
  • Обновите зависимость typescript до 4.8.4 и @types/node до 18.11.0
  • Запустите проверку типа еще раз, теперь она должна завершиться ошибкой

Вы ищете ChangeEvent<HTMLInputElement>?

LeoDog896 21.10.2022 14:58

тогда я получаю Type '(event: ChangeEvent<HTMLInputElement>) => void' is not assignable to type 'Event'.

baitendbidz 21.10.2022 15:38

(у меня мало опыта работы с vue, но из того, что я знаю в машинописном тексте), это означает, что @change пытается установить событие, а не функцию, которая принимает событие. Хотя это немного странно. На самом деле, судя по другому вопросу StackOverflow, они используют @change = "onChange($event)". Посмотрите, работает ли это.

LeoDog896 21.10.2022 15:42
Поведение ключевого слова "this" в стрелочной функции в сравнении с нормальной функцией
Поведение ключевого слова "this" в стрелочной функции в сравнении с нормальной функцией
В JavaScript одним из самых запутанных понятий является поведение ключевого слова "this" в стрелочной и обычной функциях.
Концепция локализации и ее применение в приложениях React ⚡️
Концепция локализации и ее применение в приложениях React ⚡️
Локализация - это процесс адаптации приложения к различным языкам и культурным требованиям. Это позволяет пользователям получить опыт, соответствующий...
Улучшение производительности загрузки с помощью Google Tag Manager и атрибута Defer
Улучшение производительности загрузки с помощью Google Tag Manager и атрибута Defer
В настоящее время производительность загрузки веб-сайта имеет решающее значение не только для удобства пользователей, но и для ранжирования в...
Безумие обратных вызовов в javascript [JS]
Безумие обратных вызовов в javascript [JS]
Здравствуйте! Юный падаван 🚀. Присоединяйся ко мне, чтобы разобраться в одной из самых запутанных концепций, когда вы начинаете изучать мир...
Система управления парковками с использованием HTML, CSS и JavaScript
Система управления парковками с использованием HTML, CSS и JavaScript
Веб-сайт по управлению парковками был создан с использованием HTML, CSS и JavaScript. Это простой сайт, ничего вычурного. Основная цель -...
JavaScript Вопросы с множественным выбором и ответы
JavaScript Вопросы с множественным выбором и ответы
Если вы ищете платформу, которая предоставляет вам бесплатный тест JavaScript MCQ (Multiple Choice Questions With Answers) для оценки ваших знаний,...
1
3
142
1
Перейти к ответу Данный вопрос помечен как решенный

Ответы 1

Ответ принят как подходящий

Вам нужно вызвать событие изменения через параметр $event:

<template>
  <input type = "file" @change = "handleSelectedFiles($event)"/>
</template>

Причина, по которой вы получили ошибку, заключалась в том, что Vue пытался передать Event функции, которая принимает событие:

// what vue was trying to pass in (the type of $event)
const event: Event = { ... }

// what you actually had
const numFunction: ((event: Event) => void) => { console.info(num) }

Вот почему вам нужно вызывать функцию с локальной переменной $event, и эта функция должна принимать событие, а не специализированное событие — это может потребовать приведения с вашей стороны, если вы хотите больше подсказок типа

Вы можете найти больше информации в Документации Vue

но что это за тип $event? Если это Event, то код должен быть идентичным, и тогда я не знаю, почему он не работает. На примере документации vuejs.org/guide/essentials/event-handling.html#method-handle‌​rs

baitendbidz 21.10.2022 16:03

Судя по вашей ошибке ранее, тип $event — Event. Проблема в том, что вы не можете назначить Event на (event: Event) => void. Один воспринимает событие, а другой является событием. Я уточнил больше в своем ответе.

LeoDog896 21.10.2022 16:05

не могли бы вы сказать мне, какой параметр следует handleSelectedFiles ожидать вместо этого?

baitendbidz 21.10.2022 16:25

Из вашей ошибки типа: not assignable to type 'Event'., он ищет тип Event.

LeoDog896 21.10.2022 18:19

но функция ожидает тип Event?

baitendbidz 24.10.2022 08:29

Vue ожидает, что вы передадите $event в качестве параметра функции handleSelectedFiles: vuejs.org/guide/essentials/…

LeoDog896 24.10.2022 13:24

Другие вопросы по теме