我看过几个例子,其中 Ajax 可用于更新 div 或其他带有 id 的元素。我无法找到将 Ajax 与 Razor 视图结合使用的示例来帮助我完成以下工作。
我的页面是顶部的标准菜单,中间的正文和页脚。没有必要每次都更新页眉和页脚。事实上,我的页面只需要根据页面上的菜单点击和操作链接来更新 Body 的一部分。我正在使用使用 VS 2012 创建的 Internet 模板对此进行测试,如果这有助于我不必用一堆代码片段来混淆这个请求。我正在使用 Razor 视图和 C# 进行编码偏好。
那么,给定默认的 _Layout.cshtml 文件,我将如何通过 Ajax 加载 About 页面,即 RenderBody() 部分?我已经尝试将 Ajax.BeginForm(...) 添加到我的 _Layout.cshtml 文件中,其中一个 div 的 UpdateTargetId 与我包裹 RenderBody() 调用的 div 匹配,从我的控制器返回了一个局部视图,但这不是完全正确。我得到的只是我的部分观点。(关于页面没有菜单、页脚等,只是关于页面上的代码)
有人愿意分享一个演示此功能的链接,或者分享我想要的代码,即在不刷新整页的情况下将索引视图与关于视图交换吗?对我所缺少的东西进行一些解释会很好,但我相信我可以从一个我出错的可靠例子中推断出来。一如既往,非常感谢您的时间。
编辑:使用 Jasen 的建议 _Layout.cshtml
<nav>
<ul id="menu">
<li>@Html.ActionLink("Home", "Index", "Home")</li>
<li>@Ajax.ActionLink("About", "About", "Home", null, new AjaxOptions { HttpMethod = "get", UpdateTargetId = "body" }, new { })</li>
<li>@Html.ActionLink("Contact", "Contact", "Home")</li>
</ul>
</nav>
……
在我的 div id="body" 里面
@RenderSection("featured", required: false)
<section class="content-wrapper main-content clear-fix">
@RenderBody()
</section>
..... HomeController.cs
public ActionResult About()
{
ViewBag.Message = "Your app description page.";
return PartialView();
}
……