- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
当使用 Razor 为具有子模型的复杂模型呈现表单时,我们通常会使用分部 View 来呈现子模型。
简单示例模型:
public class BlogPost
{
public string Content { get; set; }
public List<Comment> Comments { get; set; }
}
public class Comment
{
public string Content { get; set; }
}
BlogPost.cshtml:
@model BlogPost
@Html.TextAreaFor(x => x.Content)
@for (int i = 0; i < Model.Comments.Count; i++)
{
@Html.Partial('Comment', Model.Comments[i])
}
评论.cshtml:
@model Comment
@Html.TextAreaFor(x => x.Content)
现在的问题:
假设我们要将所有字段的值发送到以 BlogPost
作为参数的 Controller 操作。这些字段将像这样发送回 Controller :
Content=The+content+of+the+BlogPost&Content=The+first+Comment&Content=The+second+Comment
但是我们需要让 MVC 将它们正确映射到 BlogPost
View 模型,我们需要这个命名约定:
Content=The+content+of+the+BlogPost&Comments[0].Content=The+first+Comment&Comments[1].Content=The+second+Comment
如何以干净的方式实现这一目标?我们只能想到两种似乎都在设计上妥协的方法:
BlogPost
作为模型传递给局部 View ,这样我们就可以像这样定义文本区域:@Html.TextAreaFor(x => x.Comments[i] .内容)
。但这意味着我们将评论的分部 View 耦合到父 View 模型——你可以想到这样一种场景,即同一个分部 View 应该在不同的上下文中使用,如果分部 View 依赖于父 View 模型,这是不可能的。此外,i
必须以某种方式传递给局部 View 。@Html.TextArea(ViewBag.Prefix + ".Content")
。有什么方法可以告诉分部 View 将某个前缀应用于所有 字段名称?
最佳答案
奇科多罗,
如果您创建类型为 Comment
的 EditorFor 模板,mvc 将为您完美地处理所有这些。但是,这仅适用于行已存在于数据库中的情况。来自 SO 的示例:
Submiting Parent & Children in razor
如果您需要即时创建新行,则必须使用一些小技巧来让字段按要求运行。我使用了 steven sandersons 网站上的一篇文章,它允许您在运行时添加集合项并且仍然保留不显眼的验证等。请参阅此 SO 问题和相关文章引用:
Editing a Variable Length List, ASP.NET MVC 3 Style with Table
关于asp.net-mvc-3 - Razor 局部 View 前缀字段名称,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/11472847/
是的,我有这个对象,属性代表数据库表列作为属性,但它们都是大写的...如何将对象的所有属性更改为小写,而不将对象转换为将属性从大写转换为小写后的数组?..我想我可以用array_change_key_
是的,我有这个对象,属性代表db表的列作为属性,但是都是大写的...如何把对象的所有属性都变成小写,而不把对象转换成将属性从大写转换为小写后的数组?..我以为我可以用array_change_key_
我目前有一个论坛的 MySQL 帖子表。这包括父帖子和子帖子。如果它是父帖子,则它有一个主题。如果它是子帖子,则包含 parent_id。 例如: TABLE posts +----+--------
我正在添加一个临时表,其中包含第二个查询将使用的文件名列表。我知道文件名可以用于sql注入(inject),所以我想使用准备好的语句。 我的工作查询的简化版本如下所示(例如可能有 50 个文件名):
MySQL中查询所有数据库名和表名 查询所有数据库 ? 1
有人能给我指出正确的方向/网站吗 在 PHP 中有没有一种方法可以通过比较来自 FORM 的字段名称和来自数据库的 column_name 来动态更新特定的表。 例如 INPUT name="emai
获取表名及注释: ? 1
我正在使用 Pyshark 来解析 Wireshark 嗅探器日志,并且在使用“get_field_value”函数检索字段值时,我使用导出的 Json 格式文件(基于 pcapny 文件)来查找字段
我已经从以下 xsd 文件创建了 java bean 人.xsd
我用 MySQL 查询浏览器生成了一个 XML。我正在尝试应用 XSLT 将结果输出到 Word 表中。每条记录一张表。 这是我的 XML 示例 Critique
我有一个 select2 下拉列表,它配置为与远程数据一起使用。但是,我的远程数据源提供的搜索结果格式似乎与 select2 不兼容。远程数据例如是这样的: ... items: [ { value:
最好的 此时我在 python 2.7 中使用 Boto3,我想要的是:我的特定 DynamoDB 表的列标题。 此时,我正在处理一个非常大的 dynamoDB 表,有 80 列和 + 1.00O.0
错误信息 我刚刚试用了 Django-Rest-Framework 3.0 quickstart tutorial (伟大的介绍顺便说一句)并在我自己的系统/表上实现它时遇到了这个错误。 Improp
我正在尝试使用 haystack-whoosh 创建多个查询,我的最后一个问题是通过放置双反斜杠解决的,但现在出现了一个新错误。我在命令提示符中收到以下错误: C:\Users\varun\De
在尝试更新文档时,我在字段 timesToDisplay 中收到上述错误。 MongoDB 版本 2.6.7。 整个模型: msg = { 'name': '',
我是一名优秀的程序员,十分优秀!