This is My View:
@foreach(var item in Model) {
@{Html.RenderPartial(\"_PhoneRow\", item);}
}
You have broken markup. It is forbidden to nest a So: element directly beneath a
. And when you have broken markup, you might get undefined result. In your case this undefined result translates by the fact that when you click on the submit button of the second form the submit event is not raised and nothing happens because the unobtrusive-ajax library lived/delegated for this event. The workaround consists into using another table.
_PhoneRo.cshtml
:@model PhoneModel
@using (Ajax.BeginForm("EditPhone", new { id = Model.Id }, new AjaxOptions { UpdateTargetId = "TR" + Model.Id }))
{
}
@Html.DisplayFor(modelItem => modelItem.PhoneNumber)
@Html.DisplayFor(modelItem => modelItem.PhoneKind)
_EditPhoneRow.cshtml
:@model PhoneModel
@using (Ajax.BeginForm("SavePhone", new { id = Model.Id }, new AjaxOptions { UpdateTargetId = "TR" + Model.Id }))
{
}
@Html.EditorFor(modelItem => modelItem.PhoneNumber)
@Html.EditorFor(modelItem => modelItem.PhoneKind)