2013-02-26 78 views

回答

26

有此帮手6 overloads

  1. @Html.EditorForModel()

    呈现~/Views/Shared/EditorTemplates/TypeName.cshtml模板,其中TypeName是您的视图模型的确切类型的名称。如果您的视图模型是一个集合(即IEnumerable<TypeName>,IList<TypeName>,TypeName[],...),ASP.NET MVC将自动为该集合的每个元素渲染相应的编辑器模板。您不需要在视图中编写任何循环来实现这一点。它由框架为您处理。

  2. @Html.EditorForModel("templatename")

    呈现的~/Views/Shared/EditorTemplates/templatename.cshtml不是依靠常规

  3. @Html.EditorForModel(new { Foo = "bar" })

    渲染默认编辑模板,但附加视点数据传递给它,你可以用ViewData["foo"]ViewBag.Foo内使用

  4. @Html.EditorForModel("templatename", new { Foo = "bar" })

    呈现的~/Views/Shared/EditorTemplates/templatename.cshtml不是依靠惯例和附加视图数据传递给它,你可以用ViewData["foo"]ViewBag.Foo

  5. @Html.EditorForModel("templatename", "fieldprefix")

    内使用渲染的~/Views/Shared/EditorTemplates/templatename.cshtml不是依靠惯例和修改这意味着,例如,如果您在此模板中拨打@Html.TextBoxFor(x => x.FooBar),您将获得name="fieldprefix.FooBar"而不是name="FooBar"

  6. @Html.EditorForModel("templatename", "fieldprefix", new { Foo = "bar" })

    呈现的~/Views/Shared/EditorTemplates/templatename.cshtml不是依靠惯例和修改导航背景下,这个模板中,这意味着,例如,如果你有这个模板内的@Html.TextBoxFor(x => x.FooBar)电话,你会得到name="fieldprefix.FooBar",而不是name="FooBar"。它还传递了一个附加视图数据给它,你可以用ViewData["foo"]ViewBag.Foo

备注内使用:模板系统将首先查找在~/Views/XXX/EditorTemplates模板,其中XXX是为这个视图和控制器的名称如果它没有发现它会查看~/Views/Shared/EditorTemplates。这可以允许更精细地调整模板。您可以在共享文件夹中拥有默认模板,可以根据每个控制器重写该模板。

相关问题