麻豆小视频在线观看_中文黄色一级片_久久久成人精品_成片免费观看视频大全_午夜精品久久久久久久99热浪潮_成人一区二区三区四区

首頁 > 開發(fā) > AJAX > 正文

MVC Ajax Helper或Jquery異步加載部分視圖

2024-09-01 08:33:05
字體:
供稿:網(wǎng)友
這篇文章主要介紹了MVC Ajax Helper或Jquery異步加載部分視圖的相關(guān)資料,需要的朋友可以參考下
 

廢話不多說了,直接給大家貼代碼了。

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文件,從控制器返回的強類型部分視圖內(nèi)容呈現(xiàn)到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中實現(xiàn)部分內(nèi)容異步加載

action中定義一個得到結(jié)果集的方法

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代碼異步調(diào)用上面的action

 $(function () {  var id = '<%=itemid %>';  $.ajax({   type: "POST",   url: "/Student/GetItemTree",   data: { title: '<%=Model.Name %>', itemid: id, page: 1 },   beforeSend: function (data) { //取回數(shù)據(jù)前    $("#itemTree").html('<span style="padding:5">數(shù)據(jù)加載中...</span>');   },   error: function (data) { //發(fā)生錯誤時//    debugger;   },   success: function (data) { //成功返回時    $("#itemTree").html(data);   }  });

   最后在分部視圖GetItemTree.ascx中寫上你要返回的數(shù)據(jù)結(jié)構(gòu)即可
   注意一點就是,如果涉及到分頁,要用AJAX分頁方式

<div style="float: left">  <%=Html.AjaxPager(resItemResourceBefore, "itemTree", "GetItemTree", "Student")%> </div>


注:相關(guān)教程知識閱讀請移步到JavaScript/Ajax教程頻道。
發(fā)表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發(fā)表
主站蜘蛛池模板: 亚洲人成网站免费播放 | 久久国产精品影视 | 国产精品性夜天天视频 | 亚洲精品午夜视频 | 色就色 综合偷拍区91网 | 久久久久电影网站 | 中文字幕一区二区三区久久 | 久久久久久亚洲国产精品 | 亚洲一区二区三区视频免费 | 欧美成人一区二区三区 | 天海翼四虎精品正在播放 | 精品999www| 久久久久久久99 | 免费黄色a | 人人舔人人舔 | 欧美精品成人一区二区三区四区 | 中国美女一级黄色片 | 蜜桃精品视频 | 亚洲电影在线观看高清免费 | 精品久久久久久久久久久久久久久久久久久 | 成人视屏网站 | 久久福利剧场 | 在线播放免费播放av片 | 日韩黄色片网站 | 欧美淫视频 | 嫩草影院在线观看网站成人 | 久久精品亚洲欧美日韩精品中文字幕 | 老司机免费福利午夜入口ae58 | 久久色播 | 91 视频网站 | 最新精品在线 | 精精国产xxxx视频在线播放7 | av电影观看| 手机免费看一级片 | 久久精品欧美一区二区三区不卡 | 一级国产精品一级国产精品片 | 在线a视频 | 做爰xxxⅹ性护士hd在线 | 欧美精品日日鲁夜夜添 | 视频一区 中文字幕 | 国产精品www|