Форум программистов, компьютерный форум, киберфорум
jQuery
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.85/13: Рейтинг темы: голосов - 13, средняя оценка - 4.85
2 / 2 / 2
Регистрация: 07.05.2013
Сообщений: 70

Ajax загрузка файлов при onchange

29.10.2015, 13:22. Показов 2677. Ответов 3
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
К примеру, есть форма, при выборе файла с компьютера, данный файл сразу же должен загружатся на сервер. Тоесть, это не submit формы, а change. В данной форме много разных полей, поэтому нужно сделать seriazlize() именно инпута с файлом, остальные инпуты в игнор.

Почему то не хочет работать, ошибок нету, serialize() просто не работает и я не отправляю на сервер "ничего".
В чем может быть проблема?
HTML5
1
2
3
4
<form method="post" id="my_awesome_form" action="" enctype="multipart/form-data">
    <input type='file' name='file' class='file' />
 
</form>
var file_input_count = 0;

JavaScript
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
$(document).ready( function() {
   var form = $('#my_awesome_form');
  form.find('input:file').change( function() {
    var file = $("input:file").serialize();
    $.ajax( {
      type: "POST",
      url: "upload.php",
      data: file,
      success: function( response ) {
        console.log( response );
      }
    } );
  } );
 
} );
0
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
29.10.2015, 13:22
Ответы с готовыми решениями:

Загрузка файлов на сервер при помощи ajax
ajax не передает изображение на сервер, js только начал познавать, я так понимаю надо как то конвектировать это изображение но что то лес...

AJAX загрузка файлов.
Как сделать загрузку файла на jQuery без дополнительных плагинов (one click, ajaxForm и т.п.) и еще обязательно без iframe (target). ...

Загрузка файлов на сервер AJAX
Cобственно имеется скрипт. Рабочий,но есть проблема при загрузке файла размером больше 33 мб ,файл не передается обработчику. Максимальный...

3
 Аватар для 2849141
127 / 97 / 74
Регистрация: 06.10.2015
Сообщений: 260
29.10.2015, 16:14
Для файлов .serialize() не подойдет, делайте вот так:

JavaScript
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
form.find('input:file').change( function() {
    send_file();
});
 
function send_file() {
    var form = document.forms.my_awesome_form;
    var formData = new FormData(form);  
    var xhr = new XMLHttpRequest();
    xhr.open("POST", "upload.php");
    xhr.onreadystatechange = function() {
        if (xhr.readyState == 4) {
            if(xhr.status == 200) {
                data = xhr.responseText;
                if(data) {
                    alert(data);
                        } else {
                            alert("Ошибка при отправке файла!");
                        }
                    }
                }
            };
    xhr.send(formData);
}
0
2 / 2 / 2
Регистрация: 07.05.2013
Сообщений: 70
29.10.2015, 20:05  [ТС]
не работает почему то.
Возвращает вот это:
JavaScript
1
2
array(0) {
}
Добавлено через 15 минут
все работает, спасибо. Я вместо $_FILES - $_POST написал в пхп файле.
А можно как то не всю форму обработать с помощью new formData. А только конкретное? в данном случае, поле с инпутом файл.
0
 Аватар для 2849141
127 / 97 / 74
Регистрация: 06.10.2015
Сообщений: 260
29.10.2015, 20:30
gt3000, пускай для этого input-а будет своя отдельная форма, где он (input) будет один.
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
29.10.2015, 20:30
Помогаю со студенческими работами здесь

Ajax загрузка файлов на сервер
Доброго времени суток. Необходимо загружать файлы на сервер с помощью ajax. Серверный язык - python, фреймворк - Flask. На клиенте - чистый...

Ajax загрузка формы из загруженного через ajax блока
Вообщем, через ajax в блок подгружается форма, из нее нужно загрузить в этот же блок др.контент. $('#form').submit(function(e){ ...

Перезагрузка JS скриптов при Ajax подгрузке файлов
Все привет. Столкнулся с такой проблемой: При подгрузке нового контента с помощью pjax, который использует JS, в свою очередь...

Как поймать onchange инпута при изменении его value
День добрый. Есть инпут. Есть скрипт который меняет value этого инпута. Как мне поставить событие на инпут которое будет...

Не работает onchange при передачи значения из select в текстовое поле
Здравствуйте. Вопрос, наверняка, очень тупой, но ответ на него я найти не могу. Мне нужно, чтобы выбраное значение в select...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
4
Ответ Создать тему
Новые блоги и статьи
Настройки VS Code
Loafer 13.04.2026
{ "cmake. configureOnOpen": false, "diffEditor. ignoreTrimWhitespace": true, "editor. guides. bracketPairs": "active", "extensions. ignoreRecommendations": true, . . .
Оптимизация кода на разграничение прав доступа к элементам формы
Maks 13.04.2026
Алгоритм из решения ниже реализован на нетиповом документе, разработанного в конфигурации КА2. Задачи, как таковой, поставлено не было, проделанное ниже исключительно моя инициатива. Было так:. . .
Контроль заполнения и очистка дат в зависимости от значения перечислений
Maks 12.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "ПланированиеПерсонала", разработанного в конфигурации КА2. Задача: реализовать контроль корректности заполнения дат назначения. . .
Архитектура слоя интернета для сервера-слоя.
Hrethgir 11.04.2026
В продолжение https:/ / www. cyberforum. ru/ blogs/ 223907/ 10860. html Знаешь что я подумал? Раз мы все источники пишем в голове ветки, то ничего не мешает добавить в голову такой источник, который сам. . .
Подстановка значения реквизита справочника в табличную часть документа
Maks 10.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "ПланированиеПерсонала", разработанного в конфигурации КА2. Задача: при выборе сотрудника (справочник Сотрудники) в ТЧ документа. . .
Очистка реквизитов документа при копировании
Maks 09.04.2026
Алгоритм из решения ниже применим как для типовых, так и для нетиповых документов на самых различных конфигурациях. Задача: при копировании документа очищать определенные реквизиты и табличную. . .
модель ЗдравоСохранения 8. Подготовка к разному выполнению заданий
anaschu 08.04.2026
https:/ / github. com/ shumilovas/ med2. git main ветка * содержимое блока дэлэй из старой модели теперь внутри зайца новой модели 8ATzM_2aurI
Блокировка документа от изменений, если он открыт у другого пользователя
Maks 08.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа, разработанного в конфигурации КА2. Задача: запретить редактирование документа, если он открыт у другого пользователя. / / . . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru