Próbuję użyć FormData do wysyłania danych przez AJAX do skryptu PHP. Wydaje się, że nie ma żadnego problemu z wartościami tekstowymi typu wejściowego, ale gdy próbuję dołączyć pliki, pojawia się błąd TypeError: Wartość nie implementuje interfejsu FormData.Javascript: TypeError: Wartość nie implementuje interfejsu FormData
Jestem nowy w FormData, ale szukałem w Internecie i nie mogłem znaleźć żadnego dokumentu na temat tego błędu.
Oto forma:
<form id="item_form" class="item_form" enctype="multipart/form-data">
<div class="">
<label for="emp_photos">photos</label>
<input id="emp_photos" class="inputText" type="file" value="" name="emp_photos">
</div>
</form>
oto Javascript:
var formData = new FormData();
formData.append('photos', $('#emp_photos').files[0]);
tu jest błąd pojawia się w Firebug
TypeError: Value does not implement interface FormData.
...igger("ajaxComplete",[N,p]),--b.active||b.event.trigger("ajaxStop")))}return N},...
jquery....min.js (line 5)
Co robię źle tutaj?
EDIT: część ajax
$.ajax({
type: 'POST',
url: '";
echo $_SESSION["url_base"];
echo "operations/add_employes',
data: formData,
xhr: function() { // custom xhr
myXhr = $.ajaxSettings.xhr();
if(myXhr.upload) { // check if upload property exists
myXhr.upload.addEventListener('progress',progressHandlingFunction, false); // for handling the progress of the upload
}
return myXhr;
},
success: function(msg) {/*...*/}
});
Gdzie jest rozmowa ajax. Czy możemy to zobaczyć? – KingKongFrog
To wydaje się być właściwym rozwiązaniem http://stackoverflow.com/questions/15259632/upload-image-as-base64-with-jquery-ajax –
Ty Tim, który pomógł mi rozwiązać to :) –