Задать вопрос
@Banan44
Full Stack

Как реализовать отправку файлов через Ajax?

Как реализовать отправку файлов через Ajax? При этом нужно отправить файл сразу после того как юзер выберет и загрузит его, т.е без всяких кнопок отправить.
  • Вопрос задан
  • 62 просмотра
Подписаться 1 Простой Комментировать
Пригласить эксперта
Ответы на вопрос 2
@beerhunter
Добавляете файл в FormData, делаете запрос вида
$.ajax({
          type: 'POST',
          url: url,
          data: formData,
          processData: false,
          contentType: false,
         ....


чтобы оно сработало сразу после выбора файла, вешаете отправку на onChange инпута с файлом
Ответ написан
@Shannon
На input(type='file') вешается функцию обработчик на событие 'change', например "uploadFiles"
При вызове функции в this.files (даже без multiple, если только 1 файл, всё равно будет this.files) будут все добавленные файлы, их можно либо добавить в единую форму и отправить все вместе. Либо отправить по одному, каждый раз создавая новую форму

function uploadFiles(e) {
    const formData = new FormData()
    for (let file of this.files) {
        formData.append('files', file)
    }

    const xhr = new XMLHttpRequest()
    xhr.upload.onloadstart = function () {
        console.log('Начали загружать')
    }
    xhr.upload.onprogress = function (event) {
        console.log(`Загрузили ${event.loaded} из ${event.total}`)
    }
    xhr.upload.onload = function () {
        console.log(`Всё отправлено`)
    }
    xhr.upload.onerror = function () {
        console.log('Произошла ошибка при отправке');
    }

    xhr.open("POST", '/upload')
    xhr.send(formData)

    xhr.onreadystatechange = function () {
        if (xhr.readyState === XMLHttpRequest.DONE) {
            if (xhr.status === 200) {
                console.log('ok')
            }
            else {
                console.log('error')
            }
        }
    }
}
Ответ написан
Комментировать
Ваш ответ на вопрос

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

Похожие вопросы