【发布时间】:2015-10-26 08:04:54
【问题描述】:
我想在 asp.net mvc 中上传表单。这是我的表格
<form id="fm" method="post" enctype="multipart/form-data">
<input type="text" name="no" id="txteno" data-bind="value: $root.PersonId" disabled="disabled" />
<input type="text" name="name" id="txtename" data-bind="value: $root.PersonName" />
<input type="file" name="file" accept="image/*" data-bind="file: {data: Photo, name: PersonPhoto, reader: someReader} " />
<button data-bind="click :$root.save" >Save</button>
</form>
我使用表单数据上传此表单。这是我的视图模型
var ViewModel = function () {
//declare observable
var perData = {
//evaluate object
};
var PerData = new FormData();
self.save = function () {
//append data
PerData.append('no',perData.PersonId()); PerData.append('name',perData.PersonName());
PerData.append('file', perData.Photo());
PerData.append('file', perData.PersonPhoto());
$.ajax({
type: "POST",
url: "/Person/FileUpload",
data: PerData,
contentType: false,
processData: false,
cache: false,
//mimeType: "multipart/form-data",
success: function () {
alert("Record Added Successfully");
},
error: function () {
alert("fail");}
});};};
var vm = new ViewModel();
ko.applyBindings(vm);
这是我的控制器
[HttpPost]
public ActionResult FileUpload(Person item,HttpPostedFileBase file)
{ //some code}
通过 ajax 发送表单成功,但传递给我的控制器的项目和文件为空。
【问题讨论】:
标签: jquery asp.net-mvc knockout.js multipartform-data