这是我的剃刀观点。要点是当我更改下拉值时,更新question-editor
div。如您所见,我正在调用一个EditorFor
.
@model Contoso.MvcApplication.Models.Question.CreateQuestionViewModel
@{
ViewBag.Title = "Create Open Question";
}
<h3>Create Question</h3>
<select id="question-type-dropdown" style="margin-bottom: 20px;">
<option value="MC">Multiple Choice</option>
<option value="O">Open Question</option>
</select>
@using (Html.BeginForm()) {
@Html.ValidationSummary(true)
<fieldset>
@Html.HiddenFor(model => model.QuestionSetId)
<legend>Question Template</legend>
<div id="question-editor">
@Html.EditorFor(model => model.Template, "_QuestionEditorBoxPartial")
</div>
<p>
<input type="submit" value="Save" />
</p>
</fieldset>
}
这是部分视图,只包含一个 EditorModelFor 来选择它应该使用哪个视图模板。
_QuestionEditorBox(部分视图)
@model Contoso.Core.Base.QuestionTemplate
@Html.EditorForModel(Contoso.Core.QuestionRepositoryManager.GetQuestionTemplateView(Model))
public abstract class Question
{
public int Id {get;set;}
public string QuestionText { get; set; }
}
public OpenQuestion : Question { ... }
public MultipleChoiceQuestion : Question { ... }
public class CreateQuestionViewModel
{
public int QuestionSetId { get; set; }
public QuestionTemplate Template { get; set; }
}
但是当我这样做时,它不会显示任何内容,因为我正在使用相同的模型执行两次 EditorFor。我尝试用 a 更改第一个 EditorFor PartialView
,但这不起作用,因为我需要模型绑定器捕获我的模型。
编辑(AJAX 方法):
$("#question-type-dropdown").change(function () {
$.get("/Question/UpdateQuestionEditorBox", { questionType: $(this).val() },
function (data) {
$("#question-editor").html(data);
});
});