我用Ajax重新加載部分視圖時有一個有趣的問題。我在主視圖中以下設置:重新加載部分視圖和Ajax - ASP.NET MVC
<div>
<div id="items">
@Html.Partial("SubView", Model.Items);
</div>
<div>
子視圖通常是如下表中的項目清單:
<table class="table table-striped">
<tr>
<th>Date</th>
<th>Time</th>
<th></th>
</tr>
@foreach (var item in Model)
{
<tr>
@Html.HiddenFor(modelItem => item.Id)
<td>@Html.DisplayFor(modelItem => item.Date)</td>
<td>@Html.DisplayFor(modelItem => item.Time)</td>
<td>
@Html.ActionLink("Delete", "Delete", new { itemId= item.Id, page = Model.PageNumber }, new { @class = "deleteItem" })
</td>
</tr>
}
DeleteItem操作控制器確實基本上是以下:
[HttpDelete]
public ActionResult DeleteItem(int itemId, int page)
{
this.dbService.DeletItem(expenseId);
return PartialView("SubView", this.GetPagedList(page));
}
在我參考主視圖的腳本中,我有以下內容翼碼:
$(document).ready(function() {
// delete expense
$(".deleteItem").click(function() {
$.ajax({
url: this.href,
type: 'delete',
success: function (result) {
$("#items").html(result);
}
});
return false;
});
也能正常工作的第一次,但第二次,只加載局部視圖 - >因爲沒有被執行的JavaScript代碼...
我是比較新的是東西,我有點困惑這是怎麼回事。 所有第三方腳本都在Layout.cshtml中呈現
請張貼您DeleteItem完整代碼以及 –
補充說,因爲我說這很簡單 – Myar