我的形式:如何從ajax獲取laravel控制器(API)中的多個圖像數據?
<form enctype="multipart/form-data" method="post" id="createProduct">
{{ csrf_field() }}
<input required name="name" type="text">
<textarea name="description"></textarea>
<input id="imageToUpload" type="file"name="images[]" multiple/>
<input type="submit" value="submit"/>
</form>
我的腳本:
$(document).ready(function(){
$.ajaxSetup({
headers: {
'X-CSRF-TOKEN': $('meta[name="csrf-token"]').attr('content')
}
});
$('#createProduct').on('submit', function(e){
e.preventDefault(e);
var redirect_url = "{{ route('products.list') }}";
var url = "{{ route('products.store') }}";
var method = $(this).attr('method');
var formData = new FormData;
for(var i = 0; i < images.length; i++){
formData.append(images[i].name, images[i])
}
var myData = {
name: $(this).find("[name='name']").val(),
description: $(this).find("[name='description']").val(),
images: formData
}
$.ajax({
type: method,
url: url,
dataType: 'JSON',
data: myData,
cache: false,
contentType: false,
processData: false,
success: function(data){
console.log(data);
window.location.href = redirect_url;
},
error: function(jqXHR, textStatus, errorThrown) {
console.log(JSON.stringify(jqXHR));
console.log("AJAX error: " + textStatus + ' : ' + errorThrown);
}
});
});
我的控制器:
public function store(Request $request){
$input = Input::all();
return Response::json([
'message' => 'Product Created Succesfully',
'data' => $input
], 200);
如何從表單發送數據(與圖像)阿賈克斯
如何從ajax中檢索數據(包含圖像)以存儲(API)功能到控制器中。
這樣我就可以處理和保存文件。
有沒有嘗試'圖像:$(this).find('#imageToUpload')。val()'而不是'images:formData' –