废话不多说了,直接给大家贴代码了。
Model:
namespace MvcApplication1.Models { public class Team { public string Preletter { get; set; } public string Name { get; set; } } }
通过jQuery异步加载部分视图
Home/Index.cshtml视图中:
@{ ViewBag.Title = \"Index\"; Layout = \"~/Views/Shared/_Layout.cshtml\"; } <h2>Index</h2> <div> <a href=\"#\" id=\"a\">通过jQuery异步</a> <br/> </div> <div id=\"result\"> </div> @section scripts { <script type=\"text/javascript\"> $(function() { $(\'#a\').click(function() { $.ajax({ url: \'@Url.Action(\"Index\",\"Home\")\', data: { pre: \'B\' }, type: \'POST\', success: function(data) { $(\'#result\').empty().append(data); } }); return false; }); }); </script> }
HomeController控制器中:
using System.Collections.Generic; using System.Linq; using System.Web.Mvc; using MvcApplication1.Models; namespace MvcApplication1.Controllers { public class HomeController : Controller { public ActionResult Index() { return View(); } [HttpPost] public ActionResult Index(string pre) { var result = GetAllTeams().Where(t => t.Preletter == pre).ToList(); ViewBag.msg = \"通过jQuery异步方式到达这里~~\"; return PartialView(\"TeamY\", result); } private List<Team> GetAllTeams() { return new List<Team>() { new Team(){Name = \"巴西队\", Preletter = \"B\"}, new Team(){Name = \"克罗地亚队\", Preletter = \"K\"}, new Team(){Name = \"巴拉圭\", Preletter = \"B\"}, new Team(){Name = \"韩国\", Preletter = \"K\"} }; } } }
部分视图TeamY.cshtml:
@model IEnumerable<MvcApplication1.Models.Team> @{ var result = string.Empty; foreach (var item in Model) { result += item.Name + \",\"; } } @ViewBag.msg.ToString() <br/> @result.Substring(0,result.Length - 1)
通过MVC Ajax Helper异步加载部分视图
Home/Index.cshtml视图中需要引用jquery.unobtrusive-ajax.js文件,从控制器返回的强类型部分视图内容呈现到UpdateTargetId指定的div中。
@{ ViewBag.Title = \"Index\"; Layout = \"~/Views/Shared/_Layout.cshtml\"; } <h2>Index</h2> <div> @Ajax.ActionLink(\"通过MVC Ajax Helper\",\"Load\",\"Home\", new {pre = \"K\"}, new AjaxOptions(){UpdateTargetId = \"result1\"}) </div> <div id=\"result1\"> </div>
HomeController控制器中:
using System.Collections.Generic; using System.Linq; using System.Web.Mvc; using MvcApplication1.Models; namespace MvcApplication1.Controllers { public class HomeController : Controller { public ActionResult Index() { return View(); } public ActionResult Load(string pre) { var result = GetAllTeams().Where(t => t.Preletter == pre).ToList(); ViewBag.msg = \"通过MVC Ajax Helper到达这里~~\"; return PartialView(\"TeamY\", result); } private List<Team> GetAllTeams() { return new List<Team>() { new Team(){Name = \"巴西队\", Preletter = \"B\"}, new Team(){Name = \"克罗地亚队\", Preletter = \"K\"}, new Team(){Name = \"巴拉圭\", Preletter = \"B\"}, new Team(){Name = \"韩国\", Preletter = \"K\"} }; } } }
部分视图和上一种方式一样。
页面刷新的方式加载部分视图方法包括:
Html.RenderPartial()
Html.RenderAction()
下面给大家介绍MVC中实现部分内容异步加载
action中定义一个得到结果集的方法
public ActionResult GetItemTree(string title, int itemid, int? page) { pp = new PagingParam(page ?? 1, VConfig.WebConstConfig.PageSize); Common.Page.PagedList<Entity.Res_Item_Resource_R> res_Item_Resource_R = iResourceService.GetRes_Item_Resource_RByItemId(itemid, pp); ViewData[\"res_Item_Resource_R\"] = res_Item_Resource_R; res_Item_Resource_R.AddParameters = new System.Collections.Specialized.NameValueCollection(); res_Item_Resource_R.AddParameters.Add(\"title\", title); res_Item_Resource_R.AddParameters.Add(\"itemid\", itemid.ToString()); ViewResult vr = new ViewResult { ViewData = ViewData, MasterName = \"\", }; return vr; }
在主页面使用下面jquery代码异步调用上面的action
$(function () { var id = \'<%=itemid %>\'; $.ajax({ type: \"POST\", url: \"/Student/GetItemTree\", data: { title: \'<%=Model.Name %>\', itemid: id, page: 1 }, beforeSend: function (data) { //取回数据前 $(\"#itemTree\").html(\'<span style=\"padding:5\">数据加载中...</span>\'); }, error: function (data) { //发生错误时 // debugger; }, success: function (data) { //成功返回时 $(\"#itemTree\").html(data); } });
最后在分部视图GetItemTree.ascx中写上你要返回的数据结构即可
注意一点就是,如果涉及到分页,要用AJAX分页方式
<div style=\"float: left\"> <%=Html.AjaxPager(resItemResourceBefore, \"itemTree\", \"GetItemTree\", \"Student\")%> </div>
本文地址:https://www.stayed.cn/item/17324
转载请注明出处。
本站部分内容来源于网络,如侵犯到您的权益,请 联系我