<td>Import Excell file:</td>
<td><input type="file" id="fileUpload" name="fileUpload" /></td>
$('#fileUpload').die().live("change", function (e) {
e.preventDefault();
var file_name = $("#fileUpload").val();
var fileName = $("#fileUpload").val();
var fileExtension = fileName.substring(fileName.lastIndexOf('.') + 1);
var file_data = $("#fileUpload").prop("files")[0];
var form_data = new FormData();
form_data.append("file", file_data);
alert("hahaha");
$.ajax({
type: 'POST',
url: '@Url.Action("ImportExcell","Uploadfile")',
data: form_data,
contentType: false,
enctype: 'multipart/form-data',
processData: false,
success: function (response) {
alert(response);
}
});
});
答案 0 :(得分:5)
以下是使用FormData
的解决方案。这个解决方案的一个警告是FormData
支持仅在现代浏览器中可用,所以不要指望这适用于IE7-9等旧浏览器。
以下列方式创建控制器操作 -
public JsonResult GetFormData(HttpPostedFileBase file, string Name)
{
return Json(true);
}
然后你的HTML将是 -
<script src="~/Scripts/jquery-1.10.2.min.js"></script>
<script>
$(function () {
$("#btnSubmit").click(function () {
$.ajax({
url: "/Home/GetFormData",
type: "POST",
data: function () {
var data = new FormData();
data.append("name", jQuery("#name").val());
data.append("file", jQuery("#file").get(0).files[0]);
return data;
}(),
contentType: false,
processData: false,
success: function (response) {
},
error: function (jqXHR, textStatus, errorMessage) {
console.log(errorMessage);
}
});
});
});
</script>
Name : <input type="text" id="name" /> <br />
File: <input type="file" id="file" /> <br />
<input type="button" value="Click" id="btnSubmit" />
呈现视图并输入某些信息时 -
单击按钮时,输出将为 -