髪を引きちぎり終わったので、助けを求めています。リストのリストを表示する短い再帰 HTML ヘルパーを作成しました。編集内容をコントローラーに戻したい。子の子は null を返し続けます。再帰を削除して、「for ループ」の 2 番目のレイヤーを強制的に通過させると、うまくいくようです。どんな手掛かり?私は RAZOR にタオルを投げ入れようとしていて、Jquery でこれらすべてを行うことを学ぶだけです...
私のコードに基づいて、モデルがポストバックされたときに問題がここに存在します(これは、投稿 ActionResult メソッドのコメントに表示されます):
Node.Name は問題ありません
Node.Children[0].Name は問題ありません
Node.Children[1].Name は問題ありません
Node.Children[1].Children = null (ここに問題があります!)
コントローラーコード
public ActionResult Y()
{
Node driverTree = new Node() { Name="Level1", Children = new List<Node>() };
driverTree.Children.Add(new Node() { Children = null, Name = "Level2A" });
driverTree.Children.Add(new Node() {Name ="Level2B", Children = new List<Node> {new Node{Name="Level3A", Children=null},
new Node{Name="Level3B", Children=null}}
});
return View(driverTree);
}
[HttpPost]
public ActionResult Y(Node Node)
{
//Keeps returning:
// Node.Name is ok
// Node.Children[0].Name is ok
// Node.Children[1].Name is ok
// Node.Children[1].Children = null (HERE LIES THE PROBLEM!)
int x = 5; //
return View();
}
}
public class Node
{
public string Name { get; set; }
public List<Node> Children { get; set; }
public bool IsChecked { get; set; }
}
コードを表示
@model JqueryUITests.Controllers.Node
@section Scripts {
@Scripts.Render("~/bundles/jqueryval")
<script src="../../Scripts/jquery-ui-1.10.3.min.js" type="text/javascript"></script>
<script src="../../Scripts/jquery-ui.unobtrusive-2.1.0.min.js" type="text/javascript"></script>
}
@helper ShowTree(List<JqueryUITests.Controllers.Node> children)
{
<ul>
@for (int i = 0; i < children.Count;i++ )
{
<li>
@Html.EditorFor(x => children[i].Name)
@if (children[i].Children != null)
{
@ShowTree(children[i].Children)
}
</li>
}
</ul>
}
@using (Html.BeginForm())
{
<ul id="tree">
<li>
@Html.EditorFor(x=>Model.Name)
@ShowTree(Model.Children)
</li>
</ul>
<p>
<input type="submit" value="Create" />
</p>
}
HTMLコード
<form action="/X/Y" method="post"> <ul id="tree">
<li>
<input class="text-box single-line" id="Name" name="Name" type="text" value="Level1" />
<ul>
<li>
<input class="text-box single-line" id="children_0__Name" name="children[0].Name" type="text" value="Level2A" />
</li>
<li>
<input class="text-box single-line" id="children_1__Name" name="children[1].Name" type="text" value="Level2B" />
<ul>
<li>
<input class="text-box single-line" id="children_0__Name" name="children[0].Name" type="text" value="Level3A" />
</li>
<li>
<input class="text-box single-line" id="children_1__Name" name="children[1].Name" type="text" value="Level3B" />
</li>
</ul>
</li>
</ul>
</li>
</ul>
<p>
<input type="submit" value="Create" />
</p>