3

モデルをコントローラーにポストしようとしていますが、FormCollection の結果は期待したものではありません。

カスタム XML サービスから TeamModel の IEnumerable を受け取りました。各 TeamModel には文字列とブール値が含まれています。文字列はチームの名前で、bool はユーザーがチームをデータベースに挿入するかどうかを示します。

コントローラ:

public ActionResult ImportTeams()
    {
        var xmlService = new XmlSoccerService();
        const string league = "Scottish Premier League";

        var model = xmlService.GetAllTeamsByLeagueAndSeason(league, "1112");
        ViewBag.League = league; 
        return View("~/Views/Admin/Database/ImportTeams.cshtml", model);
    }

    [HttpPost]
    public ActionResult ImportTeams(FormCollection collection , string league)
    {
        return RedirectToAction("ImportTeams");
    }

チームモデル:

public class TeamModel
{
    public string Name { get; set; }
    public bool Import { get; set; }
}

意見:

@model IEnumerable<TopTipFootball.XmlSoccer.Models.TeamModel>

@{
    ViewBag.Title = "Import Teams";
}

<h2>Select the teams to import into: @ViewBag.League</h2>

@using (Html.BeginForm())
{
    var league = ViewBag.League;

    @Html.HiddenFor(l => league)

    foreach (var team in Model)
    {
        <div class="editor-field">
            @Html.EditorFor(model => team.Import)
            @Html.DisplayFor(m => team.Name)      
        </div>
    }
    <p>
        <input type="submit" value="Import teams" />
    </p>
}

ビューのレンダリングされた html からの 1 つの要素:

<input checked="checked" class="check-box" data-val="true" data-val-required="The Import field is required." id="team_Import" name="team.Import" type="checkbox" value="true" />
<input name="team.Import" type="hidden" value="false" />
        Aberdeen      

いくつかの質問:

  1. コントローラーへのポストで TeamModel の IEnumerable を確実に取得するにはどうすればよいですか?
  2. 正しい方法でリーグをコントローラーに戻そうとしていますか? (隠しフィールドを通して)
4

1 に答える 1

3

代わりに for ループを使用してループしてみてください。

for(int i = 0; i < Model.Count; i++) 
{
   @Html.EditorFor(model => Model[i].Import)
   @Html.DisplayFor(m => Model[i].Name)  
}

これにより、Model_ 0 _Import などの ID と名前が作成され、投稿に正しくバインドされることを願っています。

はい、このように非表示フィールドを使用しました。もちろん、リーグは正しく投稿されていると思いますが、そうでないアイテムのリストだけですか?

編集:viewBagとModelの組み合わせを使用するのではなく、常にviewModelを使用する道をたどることができますか?

ここにいくつかの助けを提供するかもしれない1つの解決策がありますか?

public ActionResult ImportTeams()
{
    const string league = "Scottish Premier League";

    var viewModel = new LeagueTeamViewModel
    {
       League = league;
    }

    var xmlService = new XmlSoccerService();        
    var model = xmlService.GetAllTeamsByLeagueAndSeason(league, "1112");

    viewModel.Teams.AddRange(xmlService.GetAllTeamsByLeagueAndSeason(league, "1112").Select(p => new TeamViewModel
    {
       Name = p.Name,
       Import = p.Import
    };

    return View("ImportTeams", viewModel);
}

[HttpPost]
public ActionResult ImportTeams(LeagueTeamViewModel viewModel)
{
}

public class LeagueTeamViewModel 
{
   public string League { get; set; }

   private List<TeamViewModel> _teams = new List<TeamViewModel>();

   public List<TeamViewModel> Teams
   {
      get { return _teams; }
      set { _teams = value; }
   }
}

public class TeamViewModel
{
   [DisplayName("Name")]
   public string Name { get; set; |

   [DisplayName("Imported")]
   public string Import { get; set; |
}

そしてあなたの見解

@model IEnumerable<LeagueTeamViewModel>
@{
    ViewBag.Title = "Import Teams";
}

<h2>Select the teams to import into: @Model.League</h2>

@using (Html.BeginForm())
{
    @Html.HiddenFor(model => model.League)

    for(int i = 0; i < Model.Teams.Count; i++) 
    {
        <div class="editor-field">
            @Html.EditorFor(model => model.Teams[i].Import)
            @Html.HiddenFor(m => model.Teams[i].Name)      
        </div>
    }
    <p>
        <input type="submit" value="Import teams" />
    </p>
}
于 2012-11-20T00:10:51.353 に答える