1

私は次のようにcshtmlページを作成しています:-

@model MvcCommons.ViewModels.CompositeViewModel
@{
    ViewBag.Title = "Create";
}

<h2>Create</h2>

<script src="@Url.Content("~/Scripts/jquery.validate.min.js")"></script>
<script src="@Url.Content("~/Scripts/jquery.validate.unobtrusive.min.js")"></script>


@using (Html.BeginForm()) {
@Html.ValidationSummary(true)

<fieldset>
    <legend>Article</legend>

    <div class="editor-label">
        @Html.LabelFor(model => model.ArticleViewModel.Article.ArticleTitle)
    </div>
    <div class="editor-field">
        @Html.EditorFor(model => model.ArticleViewModel.Article.ArticleTitle)
        @Html.ValidationMessageFor(model => model.ArticleViewModel.Article.ArticleTitle)
    </div>

    <div class="editor-label">
        @Html.LabelFor(model => model.ArticleViewModel.Article.ArticleDate)
    </div>
    <div class="editor-field">
        @Html.EditorFor(model => model.ArticleViewModel.Article.ArticleDate)
        @Html.ValidationMessageFor(model => model.ArticleViewModel.Article.ArticleDate)
    </div>

    <div class="editor-label">
        @Html.LabelFor(model => model.ArticleViewModel.Article.ArticleText)
    </div>
    <div class="editor-field">
        @Html.EditorFor(model => model.ArticleViewModel.Article.ArticleText)
        @Html.ValidationMessageFor(model => model.ArticleViewModel.Article.ArticleText)
    </div>

    <div class="editor-label">
        @Html.LabelFor(model => model.ArticleViewModel.Article.ArticleSource)
    </div>
    <div class="editor-field">
        @Html.EditorFor(model => model.ArticleViewModel.Article.ArticleSource)
        @Html.ValidationMessageFor(model => model.ArticleViewModel.Article.ArticleSource)
    </div>

    <div class="editor-label">
        @Html.LabelFor(model => model.ArticleViewModel.Article.CategoryID, "Category")
    </div>
    <div class="editor-field">
        @Html.DropDownList("CategoryID", String.Empty)
        @Html.ValidationMessageFor(model => model.ArticleViewModel.Article.CategoryID)
    </div>

    <p>
        <input type="submit" value="Create" />
    </p>
</fieldset>
}

<div>
    @Html.ActionLink("Back to List", "Index")
</div>

そして、次のようにCreate Action内でviewModelを取得しています:-

        [HttpPost]
    public ActionResult Create(CompositeViewModel viewModel)
    {
        if (ModelState.IsValid)
        {
            unitOfWork.ArticleRepository.Insert(viewModel.ArticleViewModel.Article);
            unitOfWork.Save();
            return RedirectToAction("Index");
        }

        PopulateDropDownList(viewModel.ArticleViewModel.Article.CategoryID);
        return View(viewModel);
    }

PopulateDropDownList コードは次のとおりです。

        private void PopulateDropDownList(object selectedCategory = null)
    {
        var categoryQuery = unitOfWork.CategoryRepository.Get(
                        orderBy: q => q.OrderBy(d => d.CategoryTitle));
        ViewBag.CategoryID = new SelectList(unitOfWork.CategoryRepository.Get(), "CategoryID", "CategoryTitle", selectedCategory);

    }

私の問題は、ドロップダウン リストで選択した値に関係なく、CompositeViewModel ビューモデル内の CategoryID が常に 0 であることです。Create cshtml に入力されたその他のデータは、viewModel 内に正しく入力されます。

私は自分が間違っていることを見つけることができません。

あなたの助けと時間をありがとう

4

2 に答える 2

2

DropDownListForを使用していませんか:

@Html.DropDownListFor(model => model.ArticleViewModel.Article.CategoryID, (SelectList)ViewBag.CategoryID) 
于 2012-08-23T08:01:39.197 に答える
1

あなたは書くべきです

@Html.DropDownList("ArticleViewModel.Article.CategoryID", ViewBag.CategoryID, null)

そのため、ModelBinding が正しく機能するか、DropDownListFor<>().

于 2012-08-23T08:00:25.090 に答える