これが私のかみそりの見方です。主なポイントは、ドロップダウン値が変更され、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 を 2 回実行しているため、何も表示されません。最初の EditorFor を で変更しようとしましたPartialView
が、モデル バインダーがモデルをキャッチする必要があるため、これは機能しません。
編集(AJAXメソッド):
$("#question-type-dropdown").change(function () {
$.get("/Question/UpdateQuestionEditorBox", { questionType: $(this).val() },
function (data) {
$("#question-editor").html(data);
});
});