bev*_*qua 4 c# model-view-controller asp.net-mvc-3
这是我的偏见:
@model RazorSharpBlog.Models.MarkdownTextAreaModel
<div class="wmd-panel">
<div id="wmd-button-bar-@Model.Name"></div>
@Html.TextAreaFor(m => m.Name, new { @id = "wmd-input-" + @Model.Name, @class = "wmd-input" })
</div>
<div class="wmd-panel-separator"></div>
<div id="wmd-preview-@Model.Name" class="wmd-panel wmd-preview"></div>
<div class="wmd-panel-separator"></div>
Run Code Online (Sandbox Code Playgroud)
我试图将它包含在我的中View:
@using (Html.BeginForm())
{
@Html.LabelFor(m => m.Title)
@Html.TextBoxFor(m => m.Title)
@Html.Partial("MarkdownTextArea", new { Name = "content" })
<input type="submit" value="Post" />
}
Run Code Online (Sandbox Code Playgroud)
这些是模型类:
public class MarkdownTextAreaModel
{
[Required]
public string Name { get; set; }
}
public class BlogContentModel
{
[Required]
[Display(Name = "Post Title")]
public string Title { get; set; }
[Required]
[DataType(DataType.MultilineText)]
[Display(Name = "Post Content")]
public string Content { get; set; }
}
Run Code Online (Sandbox Code Playgroud)
我做错了什么,为了使我的部分可重复使用,我应该怎么做?
Dar*_*rov 14
你的部分期望一个MarkdownTextAreaModel类的实例.所以这样做,而不是传递一个无论如何都会抛出的匿名对象:
@Html.Partial("MarkdownTextArea", new MarkdownTextAreaModel { Name = "content" })
Run Code Online (Sandbox Code Playgroud)
现在要说的是一个更好的解决方案是调整你的视图模型,以便它包含对视图的引用MarkdownTextAreaModel和使用编辑器模板而不是部分视图,就像这样:
public class BlogContentModel
{
[Required]
[Display(Name = "Post Title")]
public string Title { get; set; }
[Required]
[DataType(DataType.MultilineText)]
[Display(Name = "Post Content")]
public string Content { get; set; }
public MarkdownTextAreaModel MarkDown { get; set; }
}
Run Code Online (Sandbox Code Playgroud)
然后当然重新接受服务于此视图的控制器,以便填充MarkDown视图模型:
public ActionResult Foo()
{
BlogContentModel model = .... fetch this model from somewhere (a repository?)
model.MarkDown = new MarkdownTextAreaModel
{
Name = "contect"
};
return View(model);
}
Run Code Online (Sandbox Code Playgroud)
然后在主视图中简单地说:
@using (Html.BeginForm())
{
@Html.LabelFor(m => m.Title)
@Html.TextBoxFor(m => m.Title)
@Html.EditorFor(x => x.MarkDown)
<input type="submit" value="Post" />
}
Run Code Online (Sandbox Code Playgroud)
然后为了遵循标准惯例,将你的部分转移到~/Views/YourControllerName/EditorTemplates/MarkdownTextAreaModel.cshtml现在,现在一切都会神奇地到位.
| 归档时间: |
|
| 查看次数: |
19872 次 |
| 最近记录: |