検索可能なアイテムのリストがあり、ページにはページネーションがあります。検索クエリを入力すると、部分ビューが正しく読み込まれます (AJAX)。ただし、ページネーションを使用すると、非 ajax リクエストが発生します (ページ全体がリロードされ、ヘッダーに XmlHttpRequest フラグはありません)。
これは何が原因ですか?
$(function () {
// Adds Ajax to pagination of search results
var getPage = function () {
var $a = $(this);
var options = {
url: $a.attr("href"),
type: "get",
data: $("form").serialize()
};
$.ajax(options).done(function (data) {
var $target = $a.parents("div.pagedlist").attr("data-nn-target");
var $newHtml = $(data);
$target.html($newHtml);
$newHtml.effect("highlight");
});
// Prevent default action
return false;
};
$(".main-content").on("click", ".pagedlist a", getPage);
});
<form method="GET" action='@Url.Action("Index", "Show")' data-nn-ajax="true" data-nn-target="#contentlist" class="form-search">
<div class="input-append mysearch">
<input type="search" class="span5 search-query" name="query" data-nn-autocomplete="@Url.Action("AutoComplete")" />
<input type="submit" class="btn" value="Search" />
</div>
</form>
<div id="contentlist">
<table></table> // content
<div class="pagedlist" data-nn-target="#contentlist">
@Html.PagedListPager(Model, page => Url.Action("Index", new { page }), PagedListRenderOptions.MinimalWithItemCountText)
</div>
</div>
チュートリアルによると、このコード行は、結果セットにページネーションを使用できないという問題を解決するはずです。
data: $("form").serialize()
public ActionResult Index(string query = "", int page = 1) {
IPagedList<ShowViewModel> model;
if (Request.IsAjaxRequest()) {
model = ViewModelFactory.Instance.CreateShowViewModels(_showRepository.GetShows()
.Where(
x =>
x.Title.ToLower()
.Contains(
query.ToLower())))
.OrderByDescending(x => x.LatestRelease).ToList().ToPagedList(page, 15);
ViewBag.Search = query;
return PartialView("_Shows", model);
}
model = ViewModelFactory.Instance.CreateShowViewModels(_showRepository.GetShows()).OrderByDescending(x => x.LatestRelease).ToList().ToPagedList(page, 15);
ViewBag.Search = null;
return View(model);
}
View
と呼び出しの両方にブレークポイントを置くと、ページネーションを使用PartialView
するたびにブレークポイントにヒットしView
ます (そのため、毎回すべてのデータが表示されます)。リクエストが AJAX リクエストとして認識されないのはなぜですか?