我有一个包含局部视图的主视图。局部视图模型有一个称为"HttpPostedFileBase文件“的属性,以及其他属性
然而,当主视图被发布时,该模型中的所有其他属性都将获得正确的值,但"HttpPostedFileBase文件“为空。我已经将的名称设置为与参数相同。即使是Request.Files也给了我0个文件数量。
我做错了什么?
附注:我的主视图实际上有两个部分视图。一个PV与主视图具有相同的模型。第二个就是我上面提到的。该模型包含一个对象列表和HttpPostedFileBase文件。代码如下:
public class MyPartialViewModel
{
public List<MyObject> objInfos { get; set; }
public ICollection<HttpPostedFileBase> file { get; set; }
}在PV中,我大量使用@Html.EditFor(model=>model.objInfosi)将其绑定到模板。
因此,在主视图post方法中,我可以获得"objInfos“列表&所有对象的值都是正确的。但是"file“的值只是NULL。
发布于 2012-11-09 09:25:37
尝试将enctype = "multipart/form-data"添加为@Html.BeginForm()帮助器中的htmlAttributes之一。
编辑:不进行可视化完整回发:
AJAX FILE Upload in MVC3 using iFrame
在这个恰当的时刻,我正在使用这种方法,实际上在我们编写的时候实现了这个方法。
发布于 2012-11-27 06:55:12
我刚刚遇到了同样的问题,并通过在ActionResult中放置一个额外的参数来获取文件上传参数来解决这个问题。
[Authorize]
[HttpPost]
public ActionResult MyActionResult(MyViewModel viewModel, HttpPostedFileBase myFileToUpload)
{
myViewModel.PartialViewModel.MyFileToUpload = myFileToUpload;
//manually bind MyFileToUpload;
//for some reason, because it's in the Partial View and it's of type HttpPostedFileBase, it won't post.
return View(viewModel);
}仅供参考:
我的PartialViewModel包含以下代码:
public HttpPostedFileBase MyFileToUpload{ get; set; }并对代码执行PartialView:
<div class="editor-item">
<div class="editor-label">
@Html.LabelFor(model => model.MyFileToUpload)
</div>
<div class="editor-field">
@Html.EditorFor(model => model.MyFileToUpload)
</div>
</div>最后,我有了一个EditorTemplate Views/Shared/EditorTemplates/HttpPostedFileBase.cshtml:
@model HttpPostedFileBase
<input type="file" name="@ViewData.ModelMetadata.PropertyName" />这是一种变通方法,而不是解决方案,但它确实使您能够在将HttpPostedFileBase保留在PartialViewModel中的同时上传文件。
https://stackoverflow.com/questions/13300752
复制相似问题