JQuery異步加載PartialView的方法
本文實(shí)例講述了JQuery異步加載PartialView的方法。分享給大家供大家參考,具體如下:
需求:頁(yè)面上有dropdown之類的控件,當(dāng)選擇里面不同值的時(shí)候,下面關(guān)聯(lián)的內(nèi)容跟著改變。
思路:把與 dropdown關(guān)聯(lián)的會(huì)改變的內(nèi)容放到PartialView(ascx)里,用JQuery綁定dropdown的change事件,當(dāng)選擇值改變時(shí),用JQuery ajax請(qǐng)求與PartialView相關(guān)的Action,得到數(shù)據(jù)后講取到的內(nèi)容覆蓋原來(lái)的內(nèi)容。
實(shí)現(xiàn):
Model 類:
public class User { public string UserName { get; set; } public int Age { get; set; } public int UserID { get; set; } public static List<User> GetUsers() { List<User> userList = new List<User>(); User user = null; user = new User(); user.UserID = 1; user.UserName = "小明"; user.Age = 20; userList.Add(user); user = new User(); user.UserID = 2; user.UserName = "小紅"; user.Age = 21; userList.Add(user); user = new User(); user.UserID = 3; user.UserName = "小強(qiáng)"; user.Age = 22; userList.Add(user); return userList; } public static User GetUserById(int userId) { return GetUsers().SingleOrDefault(u=>u.UserID==userId); } }
我們的PartialView:
<%@ Control Language="C#" Inherits="System.Web.Mvc.ViewUserControl<MvcApplication2.Models.User>" %> <div> <%if (Model != null) {%> 用戶名:<%=Model.UserName%><br /> 年齡:<%=Model.Age%> <%} %> </div>
主頁(yè)面:
<%@ Page Title="" Language="C#" MasterPageFile="~/Views/Shared/Site.Master" Inherits="System.Web.Mvc.ViewPage<MvcApplication2.Models.User>" %> <asp:Content ID="Content1" ContentPlaceHolderID="TitleContent" runat="server"> Index </asp:Content> <asp:Content ID="Content2" ContentPlaceHolderID="MainContent" runat="server"> <h2>Index</h2> <%=Html.DropDownList("users", ViewData["users"] as List<SelectListItem>)%> <div id="userDetails"> <%Html.RenderPartial("UserDetails", Model); %> </div> </asp:Content> <asp:Content ID="Content3" ContentPlaceHolderID="HeadMeta" runat="server"> <script language="javascript" src="/Scripts/user.js" type="text/javascript"></script> </asp:Content>
Controller類:
using System; using System.Collections.Generic; using System.Linq; using System.Web; using System.Web.Mvc; using MvcApplication2.Models; namespace MvcApplication2.Controllers { public class UserController : Controller { public ActionResult Index() { List<SelectListItem> userIdList = new List<SelectListItem>(); foreach (MvcApplication2.Models.User item in MvcApplication2.Models.User.GetUsers()) { userIdList.Add(new SelectListItem { Text = item.UserName,Value = item.UserID.ToString()}); } ViewData["users"] = userIdList; MvcApplication2.Models.User user = MvcApplication2.Models.User.GetUsers().FirstOrDefault(); return View(user); } public PartialViewResult UserDetails(int? userId) { MvcApplication2.Models.User user = null; if (userId == null) { user = MvcApplication2.Models.User.GetUsers().FirstOrDefault(); } else { user = MvcApplication2.Models.User.GetUserById(userId.Value); } return PartialView(user); } } }
我們需要在Master頁(yè)里指定我們的PartialView對(duì)應(yīng)的Action路徑,這樣實(shí)現(xiàn):
在Head里加上如下代碼:
<script language="javascript" type="text/javascript"> mySite = { actions : { userDetails: '<%=Url.Action("UserDetails","User")%>' } }; </script>
我們對(duì)應(yīng)的JS代碼:
$(document).ready(function () { $("#users").change(function () { dropDownChange(); }); }); function dropDownChange() { var userId = $("#users").val(); $.ajax({ type: "POST", url: mySite.actions.userDetails, data: { userId: userId }, success: function (data) { $("#userDetails").html(data); } }); }
這樣就實(shí)現(xiàn)了選擇相應(yīng)的user,顯示對(duì)應(yīng)的詳細(xì)信息了。
只是一個(gè)簡(jiǎn)單的Demo,希望對(duì)需要此功能的人起到幫助作用。
更多關(guān)于jQuery相關(guān)內(nèi)容感興趣的讀者可查看本站專題:《jquery中Ajax用法總結(jié)》、《jQuery表格(table)操作技巧匯總》、《jQuery拖拽特效與技巧總結(jié)》、《jQuery擴(kuò)展技巧總結(jié)》、《jQuery常見(jiàn)經(jīng)典特效匯總》、《jQuery動(dòng)畫與特效用法總結(jié)》、《jquery選擇器用法總結(jié)》及《jQuery常用插件及用法總結(jié)》
希望本文所述對(duì)大家jQuery程序設(shè)計(jì)有所幫助。
- jquery zTree異步加載簡(jiǎn)單實(shí)例分享
- JQuery異步加載無(wú)限下拉框級(jí)聯(lián)功能實(shí)現(xiàn)示例
- 自寫的jQuery異步加載數(shù)據(jù)添加事件
- jQuery異步加載數(shù)據(jù)并添加事件示例
- struts2+jquery+json實(shí)現(xiàn)異步加載數(shù)據(jù)(自寫)
- 使用jQuery異步加載 JavaScript腳本解決方案
- MVC Ajax Helper或Jquery異步加載部分視圖
- 如何使用PHP+jQuery+MySQL實(shí)現(xiàn)異步加載ECharts地圖數(shù)據(jù)(附源碼下載)
- jquery zTree異步加載、模糊搜索簡(jiǎn)單實(shí)例分享
相關(guān)文章
jquery中dom操作和事件的實(shí)例學(xué)習(xí) 下拉框應(yīng)用
jquery中dom操作和事件的實(shí)例學(xué)習(xí) 下拉框應(yīng)用實(shí)現(xiàn)代碼,需要的朋友可以參考下。2011-12-12jQuery實(shí)現(xiàn)QQ空間漢字轉(zhuǎn)拼音功能示例
這篇文章主要介紹了jQuery實(shí)現(xiàn)QQ空間漢字轉(zhuǎn)拼音功能,結(jié)合具體實(shí)例形式分析了jQuery實(shí)現(xiàn)拼音與中文漢字的轉(zhuǎn)換操作實(shí)現(xiàn)技巧,需要的朋友可以參考下2017-07-07jQuery使用siblings獲取某元素所有同輩(兄弟姐妹)元素用法示例
這篇文章主要介紹了jQuery使用siblings獲取某元素所有同輩(兄弟姐妹)元素用法,結(jié)合簡(jiǎn)單實(shí)例形式分析了siblings()函數(shù)獲取同輩元素的操作技巧,需要的朋友可以參考下2017-01-01jQuery on()綁定動(dòng)態(tài)元素出現(xiàn)的問(wèn)題小結(jié)
jQuery on()方法是官方推薦的綁定事件的一個(gè)方法。使用 on() 方法可以給將來(lái)動(dòng)態(tài)創(chuàng)建的動(dòng)態(tài)元素綁定指定的事件,通過(guò)本文給大家介紹jQuery on()綁定動(dòng)態(tài)元素出現(xiàn)的問(wèn)題小結(jié),需要的朋友參考下2016-02-02Jquery實(shí)現(xiàn)彈出層分享微博插件具備動(dòng)畫效果
此Jquery插件是一款非常實(shí)用的特效,不但有分享功能,還具備了動(dòng)畫效果,提高了用戶體驗(yàn),感興趣的朋友可以參考下哈2013-04-04jquery插件開(kāi)發(fā)之選項(xiàng)卡制作詳解
這篇文章主要為大家詳細(xì)介紹了jquery插件開(kāi)發(fā)之選項(xiàng)卡制作,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2017-08-08Hallo.js基于jQuery UI所見(jiàn)即所得的Web編輯器
Hallo.js是一個(gè)簡(jiǎn)單的富文本編輯器,基于jQuery UI的部件,利用HTML5的contentEditable功能實(shí)現(xiàn)了即時(shí)編輯功能,其主要目的是為了提供良好的書寫體驗(yàn),對(duì)Hallo.js感興趣的小伙伴們可以參考一下2016-01-01jquery移除button的inline onclick事件(已測(cè)試及兼容瀏覽器)
這種方法在Google Chrome下正常工作,但是在IE的兼容模式下會(huì)馬上調(diào)用reclick方法,這不是我們想要的效果;為了解決這個(gè)問(wèn)題,我們可以換個(gè)思路,就是延遲綁定click事件2013-01-01