首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >可使用编辑器模板枚举的mvc模型的表单提交

可使用编辑器模板枚举的mvc模型的表单提交
EN

Stack Overflow用户
提问于 2014-01-11 10:57:35
回答 2查看 342关注 0票数 1

我有一个模型视图ViewSetup的编辑器模板。我使用模板的观点被简化为

代码语言:javascript
运行
复制
@model IEnumerable<ViewSetup>
@Html.EditorFor(s => s)

我的ViewSetup编辑器模板的表单提交如下:

代码语言:javascript
运行
复制
using (Ajax.BeginForm("Edit", new AjaxOptions() { HttpMethod = "Post" }))
{   
    @Html.HiddenFor(p => p.TradingPartner.ID)
    <input type="submit" value="Save" />
}

所以基本上我需要为Enumerable的每个元素提交一个表单。但是我在表单提交上遇到了一个问题。我处理post的控制器是:

代码语言:javascript
运行
复制
public ActionResult Edit(ViewSetup formDataSent)
{
    formDataSent.Save();    
}

根据默认的模型绑定,我会为TradingPartner属性获取null,因为html中的名称是:

代码语言:javascript
运行
复制
<input name="[0].TradingPartner.ID" type="hidden" value="1"/>

我需要的是只在每个元素上提交ViewSetup对象,而不是数组。如果我可以删除名字中的索引部分,这对我来说可能是可行的。但是我不确定如何在表单提交时只获取ViewSetup对象。

EN

回答 2

Stack Overflow用户

发布于 2014-01-11 11:36:20

我敢打赌,如果您的编辑器基于一个项目而不是一个项目列表,那么您将获得更大的灵活性。

代码语言:javascript
运行
复制
@model IEnumerable<ViewSetup>

@foreach (var item in Model)
{
   @Html.EditorFor(modelItem => item.TradingPartner)
}
票数 0
EN

Stack Overflow用户

发布于 2016-09-29 05:22:19

我也有同样的问题,解决它的方法是:

代码语言:javascript
运行
复制
@foreach (var item in Model)
{
   @Html.EditorFor(modelItem => item.TradingPartner, null, "")
}

EditorFor的第三个属性为空将删除对象中的"“。

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/21058014

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档