我有一个视图模型,它绑定到一个“TreasureHuntDetails”对象,其中包含一个线索列表。这是它的数据模型的一部分。
public TreasureHuntDetails()
{
Clues = new List<Clue>();
}
[Key]
public int TreasureHuntId { get; set; }
public List<Clue> Clues { get; set; }
在页面上,我有一张桌子。foreach 循环遍历线索列表以将它们添加到表中,例如
@for (int i = 0; i < Model.Clues.Count; i++)
for 循环中的表格元素非常大,但这里有一个表格元素列的示例:
<td>@Html.DisplayFor(m => Model.Clues[i].Location)</td>
到目前为止一切都很好。然后我使用 JQuery UI 允许使用拖放重新排序表的项目,如下所示:
<script type="text/javascript">
$(document).ready(function()
{
$("#clueTable tbody").sortable().disableSelection();
});
</script>
一切都很好,我可以拖放元素。
问题是我不知道如何保存元素的新顺序并将它们保存回数据库。
我尝试的第一件事是简单地将线索列表传递给控制器方法,但我发现一旦线索列表到达控制器方法,它总是为空。
例如:
@Url.Action("ViewCluePage", @Model.Clues)
即使我发送整个@Model,其中的线索列表也始终为空。从数据模型的构造函数中删除新的列表实例化并不能解决这个问题。
我尝试的另一件事是将整个表格包装成 HTML 表单,但线索列表仍然为空。
所以基本上,这个问题实际上是两个问题:
1)为什么将模型对象发送到控制器后,线索列表总是为空。
2)如何保存项目列表的新顺序?
更新:根据@recursive 的建议,我看到在尝试将线索元素提交到 HTML 表单时出错的地方。
我在迭代线索元素的 for 循环之外使用了它:
@Html.HiddenFor(m => m.Clues)
我必须在 for 循环内添加 HiddenFor 行(对于每个线索项),以及线索项的每个属性,例如
@Html.HiddenFor(m => m.Clues[i].Id)
因此,能够将列表项发送到控制器是向前迈出的一步,但我认为我仍然需要能够反映发送到控制器时线索项的新顺序的代码。目前,在使用 JQuery sortable() 方法重新排列屏幕上元素的顺序时,这不会更改元素的顺序,因为它们存储在绑定到视图 (@Model.Clues) 的数据模型中。