ASP.NET MVC 之 AJAX
ASP.NET MVC下的AJAX
在Asp.Net MVC中,每一個Request都被route到一個Controller下的Action來處理,即一個Controller Class的一個方法。因此,如果在Action方法中完成業務邏輯,並把需要回傳的資料寫回到Response中,在客戶端再由JavaScript來處理這些回傳的資料,相信也能實現AJAX。基於這個想法,做了一個小小的Demo,實現了asp.net mvc下的ajax。
為了方便起見,客戶端JavaScript的功能就通過jQuery來實現了。
頁面檔案Html Code:
1<h2>Lunch Tracker List</h2>
2<hr />
3<!--<% using( Html.Form<LunchController>( lc => lc.Search(), FormMethod.Post )) { %>-->
4<form. id="UsersForm">
5 Choose User:<%= Html.DropDownList("Users", new SelectList(ViewData.Model.Users, "ID", "UserName"), new { id = "userName" })%> <input type="button" id="btnSearchLunch" value="Show All" />
6</form>
7<!--<%} %>-->
8<br />
9<p id="userlunchlist">
10
11</p>
12<script. type="text/javascript">
13 $(document).ready(
14 function()
15 {
16 $("#btnSearchLunch").click(function()
17 {
18 var userName = $("#userName").val();
19 $.get("/Lunch/SearchUserAjax", { name:userName }, function(data)
20 {
21 $("p#userlunchlist").empty();
22 $("p#userlunchlist").append(data);
23 $("p#userlunchlist table").show("slow");
24 });
25 });
26 }
27 );
28</script>
其中的$(document).ready(…..)是jQuery下的JavaScript實現。 .pb{} .pb textarea{font-size:14px; margin:10px; font-family:"宋體"; background:#FFFFEE; color:#000066} .pb_t{line-height:30px; font-size:14px; color:#000; text-align:center;} /* 分頁 */ .pagebox{overflow:hidden; zoom:1; font-size:12px; font-family:"宋體",sans-serif;} .pagebox span{float:left; margin-right:2px; overflow:hidden; text-align:center; background:#fff;} .pagebox span a{display:block; overflow:hidden; zoom:1; _float:left;} .pagebox span.pagebox_pre_nolink{border:1px #ddd solid; width:53px; height:21px; *height:23px; line-height:21px; text-align:center; color:#999; cursor:default;} .pagebox span.pagebox_pre{color:#3568b9; height:23px;} .pagebox span.pagebox_pre a,.pagebox span.pagebox_pre a:visited,.pagebox span.pagebox_next a,.pagebox span.pagebox_next a:visited{border:1px #9aafe5 solid; color:#3568b9; text-decoration:none; text-align:center; width:53px; cursor:pointer; height:21px; *height:23px; line-height:21px;} .pagebox span.pagebox_pre a:hover,.pagebox span.pagebox_pre a:active,.pagebox span.pagebox_next a:hover,.pagebox span.pagebox_next a:active{color:#363636; border:1px #2e6ab1 solid;} .pagebox span.pagebox_num_nonce{padding:0 8px; height:23px; line-height:23px; color:#fff; cursor:default; background:#296cb3; font-weight:bold;} .pagebox span.pagebox_num{color:#3568b9; height:23px;} .pagebox span.pagebox_num a,.pagebox span.pagebox_num a:visited{border:1px #9aafe5 solid; color:#3568b9; text-decoration:none; padding:0 8px; cursor:pointer; height:21px; *height:23px; line-height:21px;} .pagebox span.pagebox_num a:hover,.pagebox span.pagebox_num a:active{border:1px #2e6ab1 solid;color:#363636;} .pagebox span.pagebox_num_ellipsis{color:#393733; width:22px; background:none; line-height:23px;} .pagebox span.pagebox_next_nolink{border:1px #ddd solid; width:53px; height:21px; *height:23px; line-height:21px; text-align:center; color:#999; cursor:default;}
在Asp.Net MVC中,每一個Request都被route到一個Controller下的Action來處理,即一個Controller Class的一個方法。因此,如果在Action方法中完成業務邏輯,並把需要回傳的資料寫回到Response中,在客戶端再由JavaScript來處理這些回傳的資料,相信也能實現AJAX。基於這個想法,做了一個小小的Demo,實現了asp.net mvc下的ajax。
為了方便起見,客戶端JavaScript的功能就通過jQuery來實現了。
頁面檔案Html Code:
1<h2>Lunch Tracker List</h2>
2<hr />
3<!--<% using( Html.Form<LunchController>( lc => lc.Search(), FormMethod.Post )) { %>-->
4<form. id="UsersForm">
5 Choose User:<%= Html.DropDownList("Users", new SelectList(ViewData.Model.Users, "ID", "UserName"), new { id = "userName" })%> <input type="button" id="btnSearchLunch" value="Show All" />
6</form>
7<!--<%} %>-->
8<br />
9<p id="userlunchlist">
10
11</p>
12<script. type="text/javascript">
13 $(document).ready(
14 function()
15 {
16 $("#btnSearchLunch").click(function()
17 {
18 var userName = $("#userName").val();
19 $.get("/Lunch/SearchUserAjax", { name:userName }, function(data)
20 {
21 $("p#userlunchlist").empty();
22 $("p#userlunchlist").append(data);
23 $("p#userlunchlist table").show("slow");
24 });
25 });
26 }
27 );
28</script>
其中的$(document).ready(…..)是jQuery下的JavaScript實現。 .pb{} .pb textarea{font-size:14px; margin:10px; font-family:"宋體"; background:#FFFFEE; color:#000066} .pb_t{line-height:30px; font-size:14px; color:#000; text-align:center;} /* 分頁 */ .pagebox{overflow:hidden; zoom:1; font-size:12px; font-family:"宋體",sans-serif;} .pagebox span{float:left; margin-right:2px; overflow:hidden; text-align:center; background:#fff;} .pagebox span a{display:block; overflow:hidden; zoom:1; _float:left;} .pagebox span.pagebox_pre_nolink{border:1px #ddd solid; width:53px; height:21px; *height:23px; line-height:21px; text-align:center; color:#999; cursor:default;} .pagebox span.pagebox_pre{color:#3568b9; height:23px;} .pagebox span.pagebox_pre a,.pagebox span.pagebox_pre a:visited,.pagebox span.pagebox_next a,.pagebox span.pagebox_next a:visited{border:1px #9aafe5 solid; color:#3568b9; text-decoration:none; text-align:center; width:53px; cursor:pointer; height:21px; *height:23px; line-height:21px;} .pagebox span.pagebox_pre a:hover,.pagebox span.pagebox_pre a:active,.pagebox span.pagebox_next a:hover,.pagebox span.pagebox_next a:active{color:#363636; border:1px #2e6ab1 solid;} .pagebox span.pagebox_num_nonce{padding:0 8px; height:23px; line-height:23px; color:#fff; cursor:default; background:#296cb3; font-weight:bold;} .pagebox span.pagebox_num{color:#3568b9; height:23px;} .pagebox span.pagebox_num a,.pagebox span.pagebox_num a:visited{border:1px #9aafe5 solid; color:#3568b9; text-decoration:none; padding:0 8px; cursor:pointer; height:21px; *height:23px; line-height:21px;} .pagebox span.pagebox_num a:hover,.pagebox span.pagebox_num a:active{border:1px #2e6ab1 solid;color:#363636;} .pagebox span.pagebox_num_ellipsis{color:#393733; width:22px; background:none; line-height:23px;} .pagebox span.pagebox_next_nolink{border:1px #ddd solid; width:53px; height:21px; *height:23px; line-height:21px; text-align:center; color:#999; cursor:default;}
來自 “ ITPUB部落格 ” ,連結:http://blog.itpub.net/12639172/viewspace-434715/,如需轉載,請註明出處,否則將追究法律責任。
相關文章
- ASP.NET 的MVC結構之AJAXASP.NETMVC
- Asp.Net MVC 使用 AjaxASP.NETMVC
- AJAX Panels with ASP.NET MVCASP.NETMVC
- ASP.NET MVC和AJAXASP.NETMVC
- AJAX基於ASP.NET MVCASP.NETMVC
- Asp.Net MVC4系列--進階篇之AJAXASP.NETMVC
- [ASP.NET MVC 小牛之路]14 - Unobtrusive AjaxASP.NETMVC
- ASP.NET Core MVC 之模型(Model)ASP.NETMVC模型
- [Django之框架設計模型(MTV與MVC)、Ajax]Django框架模型MVC
- ASP.NET Core MVC 之檢視(Views)ASP.NETMVCView
- ASP.NET Core MVC 之佈局(Layout)ASP.NETMVC
- Asp.Net MVC 系列--進階篇之FilterASP.NETMVCFilter
- Asp.Net MVC 學習心得 之 Html HelperASP.NETMVCHTML
- ASP.NET MVC & WebApi 中實現Cors來讓Ajax可以跨域訪問ASP.NETMVCWebAPICORS跨域
- ASP.NET 使用AjaxASP.NET
- ASP.NET MVC學習之模型驗證篇ASP.NETMVC模型
- ASP.NET MVC筆記 之 Action 過濾器ASP.NETMVC筆記過濾器
- 關於jQuery在Asp.Net Mvc 框架下Ajax檔案上傳的實現jQueryASP.NETMVC框架
- ASP.NET MVC路由ASP.NETMVC路由
- ASP.NET MVC ModuleASP.NETMVC
- ASP.NET MVC TemplateASP.NETMVC
- ASP.NET MVC ErrorASP.NETMVCError
- ASP.NET MVC FilterASP.NETMVCFilter
- UpdatePanel for ASP.NET MVCASP.NETMVC
- Asp.Net Mvc5表單提交之List集合ASP.NETMVC
- Asp.Net MVC4 系列--進階篇之ViewASP.NETMVCView
- ASP.NET MVC與ASP.NET WebFormASP.NETMVCWebORM
- [ASP.NET MVC 小牛之路]01 - 理解MVC模式ASP.NETMVC模式
- Asp.Net MVC HttpPost用法ASP.NETMVCHTTP
- ASP.NET MVC 反射例子ASP.NETMVC反射
- Asp.Net MVC 快取ASP.NETMVC快取
- ASP.NET MVC ValidationASP.NETMVC
- ASP.NET MVC: Membership, OAuthASP.NETMVCOAuth
- ASP.NET MVC系列:AreaASP.NETMVC
- ASP.NET MVC系列:ModelASP.NETMVC
- ASP.NET MVC 介紹ASP.NETMVC
- ASP.Net MVC開發基礎學習筆記(4):校驗、AJAX與過濾器ASP.NETMVC筆記過濾器
- ASP.NET Core MVC 之區域性檢視(Partial Views)ASP.NETMVCView