モデルバインダーに変更を認識させようとしています。ここで何が欠けているのかわかりません。基本的に、最初のページ作成では、データベースからページ番号が取得されます。次に、並べ替え可能な作業を行います.Firebugの生のHTMLは、順番に変更を示しています. しかし、私が最初にモデルにポストバックするとき、それはポストメソッドに行くことを理解していません.他の問題は調査です. ページの順番に変更はないようです。
意見
@for (var i = 0; i < Model.Pages.Count; i++)
{
var page = Model.Pages.ElementAt(i);
@Html.Hidden("Pages[" + i + "].PageId", page.PageId, new { @class = "page_index" })
@Html.Hidden("Pages[" + i + "].PageNumber", page.PageNumber)
<li id="@page.PageId" class="sortable-item text-center ui-state-default"><span class="ui-icon ui-icon-arrowthick-2-n-s">
</span>@page.PageNumber</li>
}
</ul>
JavaScript
<script type="text/javascript">
$(document).ready(function () {
$('.sortable').sortable({
stop: function (event, ui) {
var formData = $('#editSurveryForm').serialize();
$.ajax({
url: "@Url.Action("Edit")",
data: formData,
type: 'POST',
traditional: true,
success: function () {
alert("success");
},
error: function () {
alert("fail");
}
}
);
}
});
});
</script>
コントローラ
[HttpPost]
public ActionResult Edit(Survey survey)
{
if (!ModelState.IsValid)
{
return View("EditSurvey", survey);
}
surveyRepository.UpdateSurvey(survey);
return RedirectToAction("Index", "Administration");
}