|
 |
栏目导栏 |
|
| |
|
|
|
|
 |
资料搜索 |
|
| |
|
|
|
|
 |
热门文章 |
|
| |
|
|
|
|
 |
最新文章 |
|
| |
|
|
|
| |
| |
|
|
|
| |
| asp.net ajax客户端编程+jquery:实现泛型数据的客户端数据调用、添加、删除 |
|
学asp.net ajax客户端编程有一段时间了,决定押空把这段时间学的作一个总结。个人认为asp.net ajax是众多ajax框架中功能最强大,也是最完善的(呵呵:究竟也是微软公司的产品嘛)。并且在客户端的许多编程风格经过微软公司对javascrpt的扩展后,很像asp.net编程风格:(关于asp.net ajax对javascript的扩展文档请参照,Dflying大大的文章:http://www.cnblogs.com/dflying/archive/2007/02/09/639638.html。) mBvLinux联盟 mBvLinux联盟 个人认为最好用的几个扩展: mBvLinux联盟 mBvLinux联盟 var cityList=new Sys.StringBuilder(""); //具体功能类似asp.net的StringBuilder:在字符串的连接中可提高速度 mBvLinux联盟 mBvLinux联盟 for(var i=0;i<result.length;i++) mBvLinux联盟 mBvLinux联盟 { mBvLinux联盟 mBvLinux联盟 //String.formate:它在asp.net中大家应该常用它吧,用在客户端编程也超爽。 mBvLinux联盟 mBvLinux联盟 var tabRow=String.format("<div class='row' id='lb{0}'><label>{0}:</label>{1} <a href='javascript:void(0)' onclick='onDel({0})'>Del</a></div>",result[i].ClassID,result[i].ClassName); mBvLinux联盟 mBvLinux联盟 cityList.append(tabRow); mBvLinux联盟 mBvLinux联盟 } mBvLinux联盟 mBvLinux联盟 还有很多扩展,及其javascript面向对象编程,都是挺有意思的。 mBvLinux联盟 mBvLinux联盟 需要微软对javascript作了大量的扩展,但个人认为易用性还是不够,所以我在使用的时时候,客户端编程大多还是用Jquery去做,至于jquery库我就没啥资资格说了。 mBvLinux联盟 mBvLinux联盟 转入正题:下面是我用asp.net ajax客户端编程结合jquery实现泛型数据的客户端调用,数据的添加和删除操作。 mBvLinux联盟 mBvLinux联盟 mBvLinux联盟 mBvLinux联盟 第一步:相关环境配置: mBvLinux联盟 mBvLinux联盟 (一)、Web.config配置(后边提供一个完整的供下载) mBvLinux联盟 mBvLinux联盟 (二)、页面上一的一些配置 mBvLinux联盟 mBvLinux联盟 <asp:ScriptManager ID="ScriptManager1" runat="server"> mBvLinux联盟 mBvLinux联盟 <Scripts> mBvLinux联盟 mBvLinux联盟 <asp:ScriptReference Path="AjaxScript/CityList.js" /> mBvLinux联盟 mBvLinux联盟 </Scripts> mBvLinux联盟 mBvLinux联盟 <Services> mBvLinux联盟 mBvLinux联盟 <asp:ServiceReference Path="service/CityService.asmx" /> mBvLinux联盟 mBvLinux联盟 </Services> mBvLinux联盟 mBvLinux联盟 </asp:ScriptManager> mBvLinux联盟 mBvLinux联盟 ScriptManager的声明重要性不说了,一名话:你要用asp.net ajax编程就不能没有这主。<scripts>:调用js文件;<Services>:调用web services文件, mBvLinux联盟 mBvLinux联盟 我是把客户端的代码是写在CityList.js文件中的,而ajax调用的服务端程序是放在:CityService.asmx里的.当然页面上还有:<script type="text/javascript" src="scripts/jquery.js"></script> jquery的调用. mBvLinux联盟 mBvLinux联盟 下面是:CityList.js完整程序: mBvLinux联盟 mBvLinux联盟 第二步:JS文件 mBvLinux联盟 mBvLinux联盟 mBvLinux联盟 mBvLinux联盟 // JScript 文件 mBvLinux联盟 mBvLinux联盟 var cityClass=new Object(); //定义对象,添加时使用,这个在asp.net中相当于定义了一个实体。 mBvLinux联盟 mBvLinux联盟 // 页面加载处理 mBvLinux联盟 mBvLinux联盟 $(document).ready(function() { mBvLinux联盟 mBvLinux联盟 hiddeProgress();//隐藏加载动画的div mBvLinux联盟 mBvLinux联盟 showCityList();//实现数据的调用 mBvLinux联盟 mBvLinux联盟 }); mBvLinux联盟 mBvLinux联盟 // (公用函数)显示加载进程 mBvLinux联盟 mBvLinux联盟 var showProgress=function() mBvLinux联盟 mBvLinux联盟 { mBvLinux联盟 mBvLinux联盟 $("#progress").fadeIn("fast"); mBvLinux联盟 mBvLinux联盟 } mBvLinux联盟 mBvLinux联盟 // (公用函数)隐藏加载进程 mBvLinux联盟 mBvLinux联盟 var hiddeProgress=function() mBvLinux联盟 mBvLinux联盟 { mBvLinux联盟 mBvLinux联盟 $("#progress").hide(); mBvLinux联盟 mBvLinux联盟 } mBvLinux联盟 mBvLinux联盟 //显示列表:显示调用 mBvLinux联盟 mBvLinux联盟 var showCityList=function() mBvLinux联盟 mBvLinux联盟 { mBvLinux联盟 mBvLinux联盟 showProgress(); mBvLinux联盟 mBvLinux联盟 CityService.CityList(onSuccees); //调用web service中的过程,其中CityService是类名,CityList是函数,返回调用成功处理函数是onSuccees mBvLinux联盟 mBvLinux联盟 } mBvLinux联盟 mBvLinux联盟 //显示列表明:处理显示结果 mBvLinux联盟 mBvLinux联盟 var onSuccees=function(result) mBvLinux联盟 mBvLinux联盟 { mBvLinux联盟 mBvLinux联盟 hiddeProgress(); mBvLinux联盟 mBvLinux联盟 var cityList=new Sys.StringBuilder(""); mBvLinux联盟 mBvLinux联盟 for(var i=0;i<result.length;i++) //通过循环直接调用泛型数据记录集,太牛了 mBvLinux联盟 mBvLinux联盟 { mBvLinux联盟 mBvLinux联盟 var tabRow=String.format("<div class='row' id='lb{0}'><label>{0}:</label>{1} <a href='javascript:void(0)' onclick='onDel({0})'>Del</a></div>",result[i].ClassID,result[i].ClassName); //这里就是String.format取数据的格式 mBvLinux联盟 mBvLinux联盟 cityList.append(tabRow); mBvLinux联盟 mBvLinux联盟 } mBvLinux联盟 mBvLinux联盟 $("#divList").html(cityList.toString()); //注意:如果用StringBuilder定义来接收数据的话,最后显示的时候一定要转换在字符串 mBvLinux联盟 mBvLinux联盟 } mBvLinux联盟 mBvLinux联盟 //添加:函数调用 mBvLinux联盟 mBvLinux联盟 var onCityAdd=function() mBvLinux联盟 mBvLinux联盟 { mBvLinux联盟 mBvLinux联盟 showProgress(); mBvLinux联盟 mBvLinux联盟 //为对象定义属性并赋值 mBvLinux联盟 mBvLinux联盟 cityClass.ClassID=11; mBvLinux联盟 mBvLinux联盟 cityClass.ClassName=$("#CityName").val(); mBvLinux联盟 mBvLinux联盟 CityService.AddCity(cityClass,onaddSuccees) //将这个对象直接传递到web service去处理,这也是我感到惊叹的地方 mBvLinux联盟 mBvLinux联盟 } mBvLinux联盟 mBvLinux联盟 //添加:处理添加返回结果(添加后显示添加的效果:注意,这里是取客户端的数据添加到列表中,没有读取数据库中的数据,这样做是有好处理的:速度) mBvLinux联盟 mBvLinux联盟 var onaddSuccees=function(result) mBvLinux联盟 mBvLinux联盟 { mBvLinux联盟 mBvLinux联盟 hiddeProgress(); mBvLinux联盟 mBvLinux联盟 //向数据列表中添加一列 mBvLinux联盟 mBvLinux联盟 var tabRow=String.format("<div class='row' id='lb{0}'><label>{0}:</label>{1} <a href='javascript:void(0)' onclick='onDelMessage({0})'>Del</a></div>",result,$("#CityName").val()); mBvLinux联盟 mBvLinux联盟 $("#divList").append(tabRow); //将数据添加到末尾 mBvLinux联盟 mBvLinux联盟 $("#result").html("添加成功,添加的ID值为:"+result); mBvLinux联盟 mBvLinux联盟 } mBvLinux联盟 mBvLinux联盟 //删除:删除提示 mBvLinux联盟 mBvLinux联盟 var onDelMessage=function(ClassID) mBvLinux联盟 mBvLinux联盟 { mBvLinux联盟 mBvLinux联盟 if(confirm("你真的要删除此记录吗?")==true) mBvLinux联盟 mBvLinux联盟 onDel(ClassID); mBvLinux联盟 mBvLinux联盟 } mBvLinux联盟 mBvLinux联盟 //删除:删除调用 mBvLinux联盟 mBvLinux联盟 var onDel=function(ClassID) mBvLinux联盟 mBvLinux联盟 { mBvLinux联盟 mBvLinux联盟 //注意这里显示了返回结果的全部参数(?),onDelSuccees:调用成功后的处理函数,onDelFailed:调用错误的处理函数 :ClassID:上下文(这个是传参数及其它) mBvLinux联盟 mBvLinux联盟 CityService.CityClassDel(ClassID,onDelSuccees,onDelFailed,ClassID); mBvLinux联盟 mBvLinux联盟 } mBvLinux联盟 mBvLinux联盟 //删除:删除调用处理 mBvLinux联盟 mBvLinux联盟 var onDelSuccees=function(result,context) mBvLinux联盟 mBvLinux联盟 { mBvLinux联盟 mBvLinux联盟 if(result>0) mBvLinux联盟 mBvLinux联盟 { mBvLinux联盟 mBvLinux联盟 $("#lb"+context).fadeOut("fast"); mBvLinux联盟 mBvLinux联盟 $("#result").html("成功删除了,ID为"+context+"的记录."); mBvLinux联盟 mBvLinux联盟 } mBvLinux联盟 mBvLinux联盟 else mBvLinux联盟 mBvLinux联盟 { mBvLinux联盟 mBvLinux联盟 $("#result").html("删除失败!"); mBvLinux联盟 mBvLinux联盟 } mBvLinux联盟 mBvLinux联盟 } mBvLinux联盟 mBvLinux联盟 //删除:错误处理 mBvLinux联盟 mBvLinux联盟 var onDelFailed=function() mBvLinux联盟 mBvLinux联盟 { mBvLinux联盟 mBvLinux联盟 mBvLinux联盟 mBvLinux联盟 } mBvLinux联盟 mBvLinux联盟 mBvLinux联盟 mBvLinux联盟 第三步:服务器端程序 mBvLinux联盟 mBvLinux联盟 这个好办了,大多数都挺简单的:(以下注明红色请大家注意了) mBvLinux联盟 mBvLinux联盟 <%@ WebService Language="C#" Class="CityService" %> mBvLinux联盟 mBvLinux联盟 mBvLinux联盟 mBvLinux联盟 using System; mBvLinux联盟 mBvLinux联盟 using System.Web; mBvLinux联盟 mBvLinux联盟 using System.Collections.Generic; mBvLinux联盟 mBvLinux联盟 using System.Web.Services; mBvLinux联盟 mBvLinux联盟 using System.Web.Services.Protocols; mBvLinux联盟 mBvLinux联盟 using System.Web.Script.Services; mBvLinux联盟 mBvLinux联盟 using Test.Model; mBvLinux联盟 mBvLinux联盟 using Test.BLL; mBvLinux联盟 mBvLinux联盟 mBvLinux联盟 mBvLinux联盟 [WebService(Namespace = "http://tempuri.org/")] mBvLinux联盟 mBvLinux联盟 [WebServiceBinding(ConformsTo = WsiProfiles.BasicProfile1_1)] mBvLinux联盟 mBvLinux联盟 [GenerateScriptType(typeof(Test.Model.CityClassEntity))] //注意这个地方必面声明数据类型 mBvLinux联盟 mBvLinux联盟 [ScriptService] mBvLinux联盟 mBvLinux联盟 public class CityService : System.Web.Services.WebService { mBvLinux联盟 mBvLinux联盟 mBvLinux联盟 mBvLinux联盟 /// <summary> mBvLinux联盟 mBvLinux联盟 /// 添加 mBvLinux联盟 mBvLinux联盟 /// </summary> mBvLinux联盟 mBvLinux联盟 /// <param name="model"></param> mBvLinux联盟 mBvLinux联盟 /// <returns></returns> mBvLinux联盟 mBvLinux联盟 [WebMethod] mBvLinux联盟 mBvLinux联盟 public int AddCity(CityClassEntity model) mBvLinux联盟 mBvLinux联盟 { mBvLinux联盟 mBvLinux联盟 return CityClassBLLBase.Create_CityClassInsert(model); mBvLinux联盟 mBvLinux联盟 } mBvLinux联盟 mBvLinux联盟 /// <summary> mBvLinux联盟 mBvLinux联盟 /// 显示列表 mBvLinux联盟 mBvLinux联盟 /// </summary> mBvLinux联盟 mBvLinux联盟 /// <returns>泛型数据</returns> mBvLinux联盟 mBvLinux联盟 [WebMethod] mBvLinux联盟 mBvLinux联盟 public IList<CityClassEntity> CityList() mBvLinux联盟 mBvLinux联盟 { mBvLinux联盟 mBvLinux联盟 return CityClassBLLBase.Get_CityClassAll(); mBvLinux联盟 mBvLinux联盟 } mBvLinux联盟 mBvLinux联盟 /// <summary> mBvLinux联盟 mBvLinux联盟 /// 删除 mBvLinux联盟 mBvLinux联盟 /// </summary> mBvLinux联盟 mBvLinux联盟 /// <param name="ClassID"></param> mBvLinux联盟 mBvLinux联盟 /// <returns></returns> mBvLinux联盟 mBvLinux联盟 [WebMethod] mBvLinux联盟 mBvLinux联盟 public int CityClassDel(int ClassID) mBvLinux联盟 mBvLinux联盟 { mBvLinux联盟 mBvLinux联盟 return CityClassBLLBase.Create_CityClassDelete(ClassID); mBvLinux联盟 mBvLinux联盟 } mBvLinux联盟 mBvLinux联盟 mBvLinux联盟 mBvLinux联盟 } mBvLinux联盟
Linux联盟收集整理 ,转贴请标明原始链接,如有任何疑问欢迎来本站Linux论坛讨论 |
|
|
|
|
|