Я пытаюсь загрузить изображение через AJAX, используя простую форму HTML, включая элемент input[type='file']
, и formData()
, однако, когда я проверяю formData()
, он кажется пустым, и на сервер ничего не передается.Загрузка файлов с помощью AJAX
JQuery
//Dynamically loaded form
$(document).on('submit', '.update-form', function(e) {
e.preventDefault();
var form = $(this);
amendDatabase(form);
});
function amendDatabase(form) {
var formData = new FormData(form);
console.log(formData); //This produces 'formData: No properties'
var url = 'file.php';
request = $.ajax({
url: url,
method: 'post',
data: formData,
processData: false,
contentType: false
});
request.done(function(data) {
console.log(data); //This produces an empty/blank return
});
}
file.php
function uploadFile() {
echo 'formData was passed to server';
}
uploadFile();
HTML
<form class="update-form" id="add-file" enctype="multipart/form-data">
<label for="image">Product image</label>
<input type="file" id="image" name="image" multiple="multiple">
<div class="hidden-holder">
<input type="hidden" id="action" name="action" value="file">
</div>
<div class="submit-holder">
<input type="submit">
</div>
</form>
Вы рассмотрели прошедший спор? –
@CharlotteDunois Какой переданный аргумент вы имеете в виду? – Ryan