我有一个视图,其中的侧边菜单(其中PagedList填充了没有问题的数据),这些菜单也是链接,以在同一视图上显示另一组数据。单击这些链接后,我希望更改该字段上的数据,并使侧面菜单(PagedList)保留在同一页面上。我可以将id值传递给控制器并显示数据,但“页码”值未传递。 关于如何实现这一目标的任何想法。
这是我的代码的样子
[HttpPost]
public ActionResult Index(string id, int? page)
{
try
{
id = Request.Form["newsLinkButton"];
ViewBag.Id = id;
using (myEntities db = new myEntities())
{
var getNews = db.News.Where(x => x.Show == "Yes").OrderByDescending(x => x.Date).ToList();
return View(getNews.ToPagedList(page ?? 1, 5));
}
}
catch (Exception ex)
{
return View(ex);
}
}
<div class="sidebar blue-sidebar news-sidebar no-mobile">
<h2>Recent News</h2>
@using (Html.BeginForm("Index", "News", FormMethod.Post))
{
<form id="newsForm" name="newsForm">
<ul class="white-text">
@foreach (var item in Model.OrderByDescending(x => x.Date))
{
<li>
<button id="newsLinkButton" name="newsLinkButton" type="submit" value="@item.Id">@item.Title</button>
</li>
}
</ul>
</form>
<div class="center-block">
@Html.PagedListPager(Model, page => Url.Action("Index", new { page }),
new PagedListRenderOptions()
{
DisplayLinkToFirstPage = PagedListDisplayMode.Always,
DisplayLinkToPreviousPage = PagedListDisplayMode.Always,
DisplayLinkToLastPage = PagedListDisplayMode.Always,
DisplayLinkToNextPage = PagedListDisplayMode.Always,
MaximumPageNumbersToDisplay = 3, // number of pages in line
DisplayEllipsesWhenNotShowingAllPageNumbers = false
})
</div>
}
</div>
再次感谢您的帮助。我很感激。
答案 0 :(得分:0)
我发现属性PageNumber是保存页码值的内容(是的,我知道吗?)。因此,我创建了@{ Session["page"] = Model.PageNumber; }
并传递给控制器。问题解决了。我希望这可以在将来对其他人有所帮助。