本文实例讲述了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="/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页里指定我们的PartialView对应的Action路径,这样实现:
在Head里加上如下代码:
<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程序设计有所帮助。