DDR爱好者之家 Design By 杰米
本文实例讲述了JQuery异步加载PartialView的方法。分享给大家供大家参考,具体如下:
需求:页面上有dropdown之类的控件,当选择里面不同值的时候,下面关联的内容跟着改变。
思路:把与 dropdown关联的会改变的内容放到PartialView(ascx)里,用JQuery绑定dropdown的change事件,当选择值改变时,用JQuery ajax请求与PartialView相关的Action,得到数据后讲取到的内容覆盖原来的内容。
实现:
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 = "小强"; 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>
主页面:
<%@ 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="/UploadFiles/2021-04-02/user.js">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"htmlcode"><script language="javascript" type="text/javascript"> mySite = { actions : { userDetails: '<%=Url.Action("UserDetails","User")%>' } }; </script>我们对应的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); } }); }这样就实现了选择相应的user,显示对应的详细信息了。
只是一个简单的Demo,希望对需要此功能的人起到帮助作用。
更多关于jQuery相关内容感兴趣的读者可查看本站专题:《jquery中Ajax用法总结》、《jQuery表格(table)操作技巧汇总》、《jQuery拖拽特效与技巧总结》、《jQuery扩展技巧总结》、《jQuery常见经典特效汇总》、《jQuery动画与特效用法总结》、《jquery选择器用法总结》及《jQuery常用插件及用法总结》
希望本文所述对大家jQuery程序设计有所帮助。
DDR爱好者之家 Design By 杰米
广告合作:本站广告合作请联系QQ:858582 申请时备注:广告合作(否则不回)
免责声明:本站资源来自互联网收集,仅供用于学习和交流,请遵循相关法律法规,本站一切资源不代表本站立场,如有侵权、后门、不妥请联系本站删除!
免责声明:本站资源来自互联网收集,仅供用于学习和交流,请遵循相关法律法规,本站一切资源不代表本站立场,如有侵权、后门、不妥请联系本站删除!
DDR爱好者之家 Design By 杰米
暂无评论...
更新日志
2024年11月29日
2024年11月29日
- 凤飞飞《我们的主题曲》飞跃制作[正版原抓WAV+CUE]
- 刘嘉亮《亮情歌2》[WAV+CUE][1G]
- 红馆40·谭咏麟《歌者恋歌浓情30年演唱会》3CD[低速原抓WAV+CUE][1.8G]
- 刘纬武《睡眠宝宝竖琴童谣 吉卜力工作室 白噪音安抚》[320K/MP3][193.25MB]
- 【轻音乐】曼托凡尼乐团《精选辑》2CD.1998[FLAC+CUE整轨]
- 邝美云《心中有爱》1989年香港DMIJP版1MTO东芝首版[WAV+CUE]
- 群星《情叹-发烧女声DSD》天籁女声发烧碟[WAV+CUE]
- 刘纬武《睡眠宝宝竖琴童谣 吉卜力工作室 白噪音安抚》[FLAC/分轨][748.03MB]
- 理想混蛋《Origin Sessions》[320K/MP3][37.47MB]
- 公馆青少年《我其实一点都不酷》[320K/MP3][78.78MB]
- 群星《情叹-发烧男声DSD》最值得珍藏的完美男声[WAV+CUE]
- 群星《国韵飘香·贵妃醉酒HQCD黑胶王》2CD[WAV]
- 卫兰《DAUGHTER》【低速原抓WAV+CUE】
- 公馆青少年《我其实一点都不酷》[FLAC/分轨][398.22MB]
- ZWEI《迟暮的花 (Explicit)》[320K/MP3][57.16MB]