สำหรับ MVC นี่เป็นวิธีที่ง่ายกว่า คุณต้องใช้แบบฟอร์ม Ajax และตั้งค่า AjaxOptions
@using (Ajax.BeginForm("UploadTrainingMedia", "CreateTest", new AjaxOptions() { HttpMethod = "POST", OnComplete = "displayUploadMediaMsg" }, new { enctype = "multipart/form-data", id = "frmUploadTrainingMedia" }))
{
... html for form
}
นี่คือรหัสการส่งซึ่งอยู่ในส่วนพร้อมเอกสารและเชื่อมโยงเหตุการณ์ onclick ของปุ่มเพื่อส่งแบบฟอร์ม
$("#btnSubmitFileUpload").click(function(e){
e.preventDefault();
$("#frmUploadTrainingMedia").submit();
});
นี่คือการโทรกลับที่อ้างถึงใน AjaxOptions
function displayUploadMediaMsg(d){
var rslt = $.parseJSON(d.responseText);
if (rslt.statusCode == 200){
$().toastmessage("showSuccessToast", rslt.status);
}
else{
$().toastmessage("showErrorToast", rslt.status);
}
}
ในวิธีการควบคุมสำหรับ MVC จะมีลักษณะเช่นนี้
[HttpPost]
[ValidateAntiForgeryToken]
public JsonResult UploadTrainingMedia(IEnumerable<HttpPostedFileBase> files)
{
if (files != null)
{
foreach (var file in files)
{
// there is only one file ... do something with it
}
return Json(new
{
statusCode = 200,
status = "File uploaded",
file = "",
}, "text/html");
}
else
{
return Json(new
{
statusCode = 400,
status = "Unable to upload file",
file = "",
}, "text/html");
}
}