成人精品一区二区三区中文字幕-成人精品一区二区三区-成人精品一级毛片-成人精品亚洲-日本在线视频一区二区-日本在线视频免费

導航首頁 ? 技術教程 ? MVC Ajax Helper或Jquery異步加載部分視圖
全站頭部文字 我要出現在這里
MVC Ajax Helper或Jquery異步加載部分視圖 618 2024-03-19   

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

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  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>


主站蜘蛛池模板: 拔萝卜电影| 嫦娥奔月读后感50字| 基础综合英语邱东林电子版答案| 赵煊| 在线观看高清电影| 开创盛世| 克拉之恋 电视剧| 复仇意大利| 密室逃脱电影| 本田飞度1.5自动挡多少钱| 陈冠希的艳照门| 王源个人资料简介身高| 誓不忘情 电影| 变态的视频| 何时是读书天| 重活一世电视剧免费观看| 地铁电影| 啊嗯啊嗯嗯| 小镇姑娘高清电影| 韩国电影金珠| 女同性恨| 肱骨骨折能评几级伤残| 无尽的华尔兹| 游泳池play高h| 福利视频观看| 成龙游戏| 疑云密布| 男女电视剧| 陈冠希的艳照门| 李乃文宋丹丹朱媛媛演的电视剧 | 想你的时候问月亮男声沙哑版| https://www.douyin.com/| 熊出没之雪岭熊风 2015 张伟| 罗中立的《父亲》详案| 汤姆·威尔金森| 粉嫩在线| 故乡之恋简谱| 权威的图片| 庞勇| 糟老头视频下载| 宝贝电影|

!!!站長長期在線接!!!

網站、小程序:定制開發/二次開發/仿制開發等

各種疑難雜癥解決/定制接口/定制采集等

站長微信:lxwl520520

站長QQ:1737366103