JQuery異步加載PartialView的方法
本文實例講述了JQuery異步加載PartialView的方法。分享給大家供大家參考,具體如下:
需求:頁面上有dropdown之類的控件,當選擇里面不同值的時候,下面關聯(lián)的內(nèi)容跟著改變。
思路:把與 dropdown關聯(lián)的會改變的內(nèi)容放到PartialView(ascx)里,用JQuery綁定dropdown的change事件,當選擇值改變時,用JQuery ajax請求與PartialView相關的Action,得到數(shù)據(jù)后講取到的內(nèi)容覆蓋原來的內(nèi)容。
實現(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 = "小強";
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路徑,這樣實現(xiàn):
在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);
}
});
}
這樣就實現(xiàn)了選擇相應的user,顯示對應的詳細信息了。
只是一個簡單的Demo,希望對需要此功能的人起到幫助作用。
更多關于jQuery相關內(nèi)容感興趣的讀者可查看本站專題:《jquery中Ajax用法總結(jié)》、《jQuery表格(table)操作技巧匯總》、《jQuery拖拽特效與技巧總結(jié)》、《jQuery擴展技巧總結(jié)》、《jQuery常見經(jīng)典特效匯總》、《jQuery動畫與特效用法總結(jié)》、《jquery選擇器用法總結(jié)》及《jQuery常用插件及用法總結(jié)》
希望本文所述對大家jQuery程序設計有所幫助。
- jquery zTree異步加載簡單實例分享
- JQuery異步加載無限下拉框級聯(lián)功能實現(xiàn)示例
- 自寫的jQuery異步加載數(shù)據(jù)添加事件
- jQuery異步加載數(shù)據(jù)并添加事件示例
- struts2+jquery+json實現(xiàn)異步加載數(shù)據(jù)(自寫)
- 使用jQuery異步加載 JavaScript腳本解決方案
- MVC Ajax Helper或Jquery異步加載部分視圖
- 如何使用PHP+jQuery+MySQL實現(xiàn)異步加載ECharts地圖數(shù)據(jù)(附源碼下載)
- jquery zTree異步加載、模糊搜索簡單實例分享
相關文章
jQuery實現(xiàn)QQ空間漢字轉(zhuǎn)拼音功能示例
這篇文章主要介紹了jQuery實現(xiàn)QQ空間漢字轉(zhuǎn)拼音功能,結(jié)合具體實例形式分析了jQuery實現(xiàn)拼音與中文漢字的轉(zhuǎn)換操作實現(xiàn)技巧,需要的朋友可以參考下2017-07-07
jQuery使用siblings獲取某元素所有同輩(兄弟姐妹)元素用法示例
這篇文章主要介紹了jQuery使用siblings獲取某元素所有同輩(兄弟姐妹)元素用法,結(jié)合簡單實例形式分析了siblings()函數(shù)獲取同輩元素的操作技巧,需要的朋友可以參考下2017-01-01
jQuery on()綁定動態(tài)元素出現(xiàn)的問題小結(jié)
jQuery on()方法是官方推薦的綁定事件的一個方法。使用 on() 方法可以給將來動態(tài)創(chuàng)建的動態(tài)元素綁定指定的事件,通過本文給大家介紹jQuery on()綁定動態(tài)元素出現(xiàn)的問題小結(jié),需要的朋友參考下2016-02-02
Hallo.js基于jQuery UI所見即所得的Web編輯器
Hallo.js是一個簡單的富文本編輯器,基于jQuery UI的部件,利用HTML5的contentEditable功能實現(xiàn)了即時編輯功能,其主要目的是為了提供良好的書寫體驗,對Hallo.js感興趣的小伙伴們可以參考一下2016-01-01
jquery移除button的inline onclick事件(已測試及兼容瀏覽器)
這種方法在Google Chrome下正常工作,但是在IE的兼容模式下會馬上調(diào)用reclick方法,這不是我們想要的效果;為了解決這個問題,我們可以換個思路,就是延遲綁定click事件2013-01-01

