微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

jquery – 如何通过ajax调用控件并返回HTML来在MVC5中呈现局部视图

如何使用 AJAX加载 HTML中渲染的完整部分视图(所以我只是设置了div.html)

我需要ajax调用调用控制器操作,这将使得完整的部分视图(红色)并将其附加到当前加载的操作的结尾?

[我知道如何附加到DOM和如何使AJAX调用]

我需要知道什么是最好的管道方法,什么类型的ActionResult应该行动返回,如果有一个已经内置的机制,以避免重新发明轮?

解决方法

在ASP.NET MVC中有内置的ajax帮助程序,可以覆盖基本的场景.

您需要安装并引用jquery.unobtrusive-ajax JavaScript库(jQuery依赖).然后在你的主视图(让我们说index.cshtml)放上下面的代码

Index.cshtml

@Ajax.ActionLink("Load More Posts","MorePosts",new AjaxOptions()
{
    HttpMethod = "GET",AllowCache = false,InsertionMode = InsertionMode.InsertAfter,UpdateTargetId = "posts-wrapper"
})

<div id="posts-wrapper"></div>

注意:@ Ajax.ActionLink帮助程序接受AjaxOptions参数以进行更多自定义.

在控制器(让我们说HomeController.cs)你应该返回PartialViewResult:

public ActionResult MorePosts(int? offset,int? count)
{
    IEnumerable<Post> posts = myService.GetNextPosts(offset,count); 
    return PartialView(posts);
}

最后你定义MorePosts.cshtml部分视图:

@model IEnumerable<Post>

@{
    Layout = null;
}

@foreach (var post in Model)
{
    <div class="post">
        <div>>@post.Prop1</div>
        <div>@post.Prop2</div>
    </div>
    <hr />
}

就是这样当一些用户单击“加载更多”按钮时,将会加载更多的帖子.

注1:您可以实现OnBegin函数来实现实际的逻辑,以确定哪些是下一个加载的帖子(例如,获取上次加载的帖子的ID并将其发送到服务器).

注2:使用自定义jQuery.ajax调用(不使用jquery.unobtrusive)可以实现相同的结果.唯一的区别是手动ajax调用和点击事件.

希望这可以帮助.如果需要,我可以写一个更完整的例子.

原文地址:https://www.jb51.cc/jquery/176327.html

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐