0

事前定義されたモデルのリストを編集するビューを作成しようとしています。したがって、モデルのリストをパラメーターとして受け取る、強く型付けされたビューです。カスタムHtmlヘルパーを使用して、個々のモデルを編集します。Getビューは正しく表示されますが、ポストバックビューモデル(モデルのリスト)は常にnullです。このトピックについてここに多くの質問があることを私は知っていますが、私はこれを2日間試みてきました。

基本モデルは次のとおりです。

public class PrivacyManagerModel
{
   [Required]
   [Display(Name="Privacy Type Id")]
   public int PrivaceTypeId { get; set; }

   [Required]
   [Display(Name = "Visibility Level Id")]
   public int VisibilityLevelId { get; set; }



}

コントローラのアクションは次のとおりです。

     //GET: /Profile/ManagePrivacy
    [Authorize]
    public ActionResult ManagePrivacy()
    {
        PrivacyTypeService _privacyTypeService=new PrivacyTypeService();
        IEnumerable<PrivacyFlagType> privacyTypes = _privacyTypeService.GetPrivacyFlagTypes();
        List<PrivacyManagerModel> model=new List<PrivacyManagerModel>();
        foreach (PrivacyFlagType type in privacyTypes)
        {
            PrivacyManagerModel temp=new PrivacyManagerModel();
            temp.PrivaceTypeId=type.PrivacyFlagTypeId;
            model.Add(temp);
        }


        ViewBag.privacyTypes=privacyTypes;



        return View(model);
    }

    //POST: /Profile/ManagePrivacy
    [Authorize]
    [HttpPost]
    public ActionResult ManagePrivacy(IEnumerable<PrivacyManagerModel> model)
    {

        if (ModelState.IsValid)
        {
        do stuff
        }
        else
        {
            return View(model);
        }
    }

これは、次のリストを編集しようとするビューですPrivacyManagerModel

@model IEnumerable<Klever.PrivacyManagerModel>
@using Klever
@{
 ViewBag.Title = "ManagePrivacy";
 var _privacyTypes = ViewBag.privacyTypes as IEnumerable<PrivacyFlagType>;
}

@using (Html.BeginForm()) {
@Html.ValidationSummary(true)
<fieldset>

    @foreach(PrivacyManagerModel item in Model)
    {
        <div class="display-label">
        @Html.DisplayFor(modelItem=>item.PrivaceTypeId)
        </div> 
        <div class="editor-field">
        @Html.EditorFor(modelItem=>item)
        </div>
        }

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

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

そして最後に、HtmlヘルパーEditTemplate for PrivacyManagerModel

@model Klever.PrivacyManagerModel
@using Klever.Components
<script src="@Url.Content("~/Scripts/jquery-1.5.1.min.js")" type="text/javascript"></script>
<script src="@Url.Content("~/Scripts/jquery.validate.min.js")" type="text/javascript"></script>
<script src="@Url.Content("~/Scripts/jquery.validate.unobtrusive.min.js")"    type="text/javascript"></script>

@{
PrivacyTypeService _privacyService = new PrivacyTypeService();
var visibilityLevels=_privacyService.GetVisibilityLevels();

}
<fieldset>


    <div class="editor-label">
        @Html.LabelFor(model => model.PrivaceTypeId)
    </div>
    <div class="editor-field">
        @Html.DropDownListFor(model=>model.VisibilityLevelId,new SelectList(visibilityLevels,"VisibilityLevelId","Name"))
        @Html.ValidationMessageFor(model => model.VisibilityLevelId)
    </div>
    </fieldset>

この場合も、GETアクションは正常に機能しますが(ビューが正しく表示されます)、Postアクションは常にパラメーターとしてNullモデルを受け取ります。よろしくお願いします。ありがとう

4

1 に答える 1

1

これを試すことができます。プロジェクトでMVC 3サイトに取り組んでいたときに、同様の問題が発生しました。その理由は、MVC プラットフォームがビューの値からモデルを生成できないためです。これは、foreach ループを適用し、ループ内の任意のアイテムのコントロールを "@Html.DisplayFor(modelItem=>item.PrivaceTypeId) として作成するためです。 " HTML コントロールに割り当てられる ID/名前は "item.PrivaceTypeId" になります。ただし、以下に示す例では、HTML コントロールに割り当てられた ID/名前は "Model[0].PrivaceTypeId"、"Model[1].PrivaceTypeId" などになります。これはモデル (コレクション) の作成に役立ちます。ビューの値から。

@using (Html.BeginForm()) { 
@Html.ValidationSummary(true) 
<fieldset> 

    @for(int i = 0; i <= Model.Count; i++)
    { 
        <div class="display-label"> 
        @Html.DisplayFor(modelItem=>Model[i].PrivaceTypeId) 
        </div>  
        <div class="editor-field"> 
        @Html.EditorFor(modelItem=>Model[i]) 
        </div> 
    } 

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

現在、VS を持っていないため、MVC プラットフォームがエディター テンプレートからモデルを作成できるかどうかはわかりません。確認して見ることができます。しかし、これは私にとって4〜5回機能したため、確実に機能します。

于 2012-03-22T10:43:49.343 に答える