当前位置:首页 > 网络编程 > WEB编程 > ASP.net >  asp.net ajax客户端编程+jquery:实现泛型数据的客户端数据调用、添加、删除

 asp.net ajax客户端编程+jquery:实现泛型数据的客户端数据调用、添加、删除

点击次数:19 次 发布日期:2008-11-26 10:33:40 作者:源代码网
源代码网推荐     
源代码网推荐     学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。)
源代码网推荐  
源代码网推荐   个人认为最好用的几个扩展:
源代码网推荐  
源代码网推荐   var cityList=new Sys.StringBuilder(""); //具体功能类似asp.net的StringBuilder:在字符串的连接中可提高速度
源代码网推荐  
源代码网推荐   for(var i=0;i<result.length;i++)
源代码网推荐  
源代码网推荐   {
源代码网推荐  
源代码网推荐   //String.formate:它在asp.net中大家应该常用它吧,用在客户端编程也超爽。
源代码网推荐  
源代码网推荐   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);
源代码网推荐  
源代码网推荐   cityList.append(tabRow);
源代码网推荐  
源代码网推荐   }
源代码网推荐  
源代码网推荐  还有很多扩展,及其javascript面向对象编程,都是挺有意思的。
源代码网推荐  
源代码网推荐   需要微软对javascript作了大量的扩展,但个人认为易用性还是不够,所以我在使用的时时候,客户端编程大多还是用Jquery去做,至于jquery库我就没啥资资格说了。
源代码网推荐  
源代码网推荐  转入正题:下面是我用asp.net ajax客户端编程结合jquery实现泛型数据的客户端调用,数据的添加和删除操作。
源代码网推荐  
源代码网推荐  
源代码网推荐  
源代码网推荐  第一步:相关环境配置:
源代码网推荐  
源代码网推荐   (一)、Web.config配置(后边提供一个完整的供下载)
源代码网推荐  
源代码网推荐   (二)、页面上一的一些配置
源代码网推荐  
源代码网推荐   <asp:ScriptManager ID="ScriptManager1" runat="server">
源代码网推荐  
源代码网推荐   <Scripts>
源代码网推荐  
源代码网推荐   <asp:ScriptReference Path="AjaxScript/CityList.js" />
源代码网推荐  
源代码网推荐   </Scripts>
源代码网推荐  
源代码网推荐   <Services>
源代码网推荐  
源代码网推荐   <asp:ServiceReference Path="service/CityService.asmx" />
源代码网推荐  
源代码网推荐   </Services>
源代码网推荐  
源代码网推荐   </asp:ScriptManager>
源代码网推荐  
源代码网推荐   ScriptManager的声明重要性不说了,一名话:你要用asp.net ajax编程就不能没有这主。<scripts>:调用js文件;<Services>:调用web services文件,
源代码网推荐  
源代码网推荐  我是把客户端的代码是写在CityList.js文件中的,而ajax调用的服务端程序是放在:CityService.asmx里的.当然页面上还有:<script type="text/javascript" src="http://www.zzchn.com/edu/20080727/scripts/jquery.js"></script> jquery的调用.
源代码网推荐  
源代码网推荐  下面是:CityList.js完整程序:
源代码网推荐  
源代码网推荐  第二步:JS文件
源代码网推荐  
源代码网推荐  
源代码网推荐  
源代码网推荐  // JScript 文件
源代码网推荐  
源代码网推荐  var cityClass=new Object(); //定义对象,添加时使用,这个在asp.net中相当于定义了一个实体。
源代码网推荐  
源代码网推荐  // 页面加载处理
源代码网推荐  
源代码网推荐  $(document).ready(function() {
源代码网推荐  
源代码网推荐   hiddeProgress();//隐藏加载动画的div
源代码网推荐  
源代码网推荐   showCityList();//实现数据的调用
源代码网推荐  
源代码网推荐  });
源代码网推荐  
源代码网推荐  // (公用函数)显示加载进程
源代码网推荐  
源代码网推荐  var showProgress=function()
源代码网推荐  
源代码网推荐  {
源代码网推荐  
源代码网推荐   $("#progress").fadeIn("fast");
源代码网推荐  
源代码网推荐  }
源代码网推荐  
源代码网推荐  // (公用函数)隐藏加载进程
源代码网推荐  
源代码网推荐  var hiddeProgress=function()
源代码网推荐  
源代码网推荐  {
源代码网推荐  
源代码网推荐   $("#progress").hide();
源代码网推荐  
源代码网推荐  }
源代码网推荐  
源代码网推荐  //显示列表:显示调用
源代码网推荐  
源代码网推荐  var showCityList=function()
源代码网推荐  
源代码网推荐  {
源代码网推荐  
源代码网推荐   showProgress();
源代码网推荐  
源代码网推荐   CityService.CityList(onSuccees); //调用web service中的过程,其中CityService是类名,CityList是函数,返回调用成功处理函数是onSuccees
源代码网推荐  
源代码网推荐  }
源代码网推荐  
源代码网推荐  //显示列表明:处理显示结果
源代码网推荐  
源代码网推荐  var onSuccees=function(result)
源代码网推荐  
源代码网推荐  {
源代码网推荐  
源代码网推荐   hiddeProgress();
源代码网推荐  
源代码网推荐   var cityList=new Sys.StringBuilder("");
源代码网推荐  
源代码网推荐   for(var i=0;i<result.length;i++) //通过循环直接调用泛型数据记录集,太牛了
源代码网推荐  
源代码网推荐   {
源代码网推荐  
源代码网推荐   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取数据的格式
源代码网推荐  
源代码网推荐   cityList.append(tabRow);
源代码网推荐  
源代码网推荐   }
源代码网推荐  
源代码网推荐   $("#divList").html(cityList.toString()); //注意:如果用StringBuilder定义来接收数据的话,最后显示的时候一定要转换在字符串
源代码网推荐  
源代码网推荐  }
源代码网推荐  
源代码网推荐  //添加:函数调用
源代码网推荐  
源代码网推荐  var onCityAdd=function()
源代码网推荐  
源代码网推荐  {
源代码网推荐  
源代码网推荐   showProgress();
源代码网推荐  
源代码网推荐   //为对象定义属性并赋值
源代码网推荐  
源代码网推荐   cityClass.ClassID=11;
源代码网推荐  
源代码网推荐   cityClass.ClassName=$("#CityName").val();
源代码网推荐  
源代码网推荐   CityService.AddCity(cityClass,onaddSuccees) //将这个对象直接传递到web service去处理,这也是我感到惊叹的地方
源代码网推荐  
源代码网推荐  }
源代码网推荐  
源代码网推荐  //添加:处理添加返回结果(添加后显示添加的效果:注意,这里是取客户端的数据添加到列表中,没有读取数据库中的数据,这样做是有好处理的:速度)
源代码网推荐  
源代码网推荐  var onaddSuccees=function(result)
源代码网推荐  
源代码网推荐  {
源代码网推荐  
源代码网推荐   hiddeProgress();
源代码网推荐  
源代码网推荐   //向数据列表中添加一列
源代码网推荐  
源代码网推荐   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());
源代码网推荐  
源代码网推荐   $("#divList").append(tabRow); //将数据添加到末尾
源代码网推荐  
源代码网推荐   $("#result").html("添加成功,添加的ID值为:"+result);
源代码网推荐  
源代码网推荐  }
源代码网推荐  
源代码网推荐  //删除:删除提示
源代码网推荐  
源代码网推荐  var onDelMessage=function(ClassID)
源代码网推荐  
源代码网推荐  {
源代码网推荐  
源代码网推荐   if(confirm("你真的要删除此记录吗?")==true)
源代码网推荐  
源代码网推荐   onDel(ClassID);
源代码网推荐  
源代码网推荐  }
源代码网推荐  
源代码网推荐  //删除:删除调用
源代码网推荐  
源代码网推荐  var onDel=function(ClassID)
源代码网推荐  
源代码网推荐  {
源代码网推荐  
源代码网推荐   //注意这里显示了返回结果的全部参数(?),onDelSuccees:调用成功后的处理函数,onDelFailed:调用错误的处理函数 :ClassID:上下文(这个是传参数及其它)
源代码网推荐  
源代码网推荐   CityService.CityClassDel(ClassID,onDelSuccees,onDelFailed,ClassID);
源代码网推荐  
源代码网推荐  }
源代码网推荐  
源代码网推荐  //删除:删除调用处理
源代码网推荐  
源代码网推荐  var onDelSuccees=function(result,context)
源代码网推荐  
源代码网推荐  {
源代码网推荐  
源代码网推荐   if(result>0)
源代码网推荐  
源代码网推荐   {
源代码网推荐  
源代码网推荐   $("#lb"+context).fadeOut("fast");
源代码网推荐  
源代码网推荐   $("#result").html("成功删除了,ID为"+context+"的记录.");
源代码网推荐  
源代码网推荐   }
源代码网推荐  
源代码网推荐   else
源代码网推荐  
源代码网推荐   {
源代码网推荐  
源代码网推荐   $("#result").html("删除失败!");
源代码网推荐  
源代码网推荐   }
源代码网推荐  
源代码网推荐  }
源代码网推荐  
源代码网推荐  //删除:错误处理
源代码网推荐  
源代码网推荐  var onDelFailed=function()
源代码网推荐  
源代码网推荐  {
源代码网推荐  
源代码网推荐  
源代码网推荐  
源代码网推荐  }
源代码网推荐  
源代码网推荐  
源代码网推荐  
源代码网推荐  第三步:服务器端程序
源代码网推荐  
源代码网推荐  这个好办了,大多数都挺简单的:(以下注明红色请大家注意了)
源代码网推荐  
源代码网推荐  <%@ WebService Language="C#" Class="CityService" %>
源代码网推荐  
源代码网推荐  
源代码网推荐  
源代码网推荐  using System;
源代码网推荐  
源代码网推荐  using System.Web;
源代码网推荐  
源代码网推荐  using System.Collections.Generic;
源代码网推荐  
源代码网推荐  using System.Web.Services;
源代码网推荐  
源代码网推荐  using System.Web.Services.Protocols;
源代码网推荐  
源代码网推荐  using System.Web.Script.Services;
源代码网推荐  
源代码网推荐  using Test.Model;
源代码网推荐  
源代码网推荐  using Test.BLL;
源代码网推荐  
源代码网推荐  
源代码网推荐  
源代码网推荐  [WebService(Namespace = "http://tempuri.org/")]
源代码网推荐  
源代码网推荐  [WebServiceBinding(ConformsTo = WsiProfiles.BasicProfile1_1)]
源代码网推荐  
源代码网推荐  [GenerateScriptType(typeof(Test.Model.CityClassEntity))] //注意这个地方必面声明数据类型
源代码网推荐  
源代码网推荐  [ScriptService]
源代码网推荐  
源代码网推荐  public class CityService : System.Web.Services.WebService {
源代码网推荐  
源代码网推荐  
源代码网推荐  
源代码网推荐   /// <summary>
源代码网推荐  
源代码网推荐   /// 添加
源代码网推荐  
源代码网推荐   /// </summary>
源代码网推荐  
源代码网推荐   /// <param name="model"></param>
源代码网推荐  
源代码网推荐   /// <returns></returns>
源代码网推荐  
源代码网推荐   [WebMethod]
源代码网推荐  
源代码网推荐   public int AddCity(CityClassEntity model)
源代码网推荐  
源代码网推荐   {
源代码网推荐  
源代码网推荐   return CityClassBLLBase.Create_CityClassInsert(model);
源代码网推荐  
源代码网推荐   }
源代码网推荐  
源代码网推荐   /// <summary>
源代码网推荐  
源代码网推荐   /// 显示列表
源代码网推荐  
源代码网推荐   /// </summary>
源代码网推荐  
源代码网推荐   /// <returns>泛型数据</returns>
源代码网推荐  
源代码网推荐   [WebMethod]
源代码网推荐  
源代码网推荐   public IList<CityClassEntity> CityList()
源代码网推荐  
源代码网推荐   {
源代码网推荐  
源代码网推荐   return CityClassBLLBase.Get_CityClassAll();
源代码网推荐  
源代码网推荐   }
源代码网推荐  
源代码网推荐   /// <summary>
源代码网推荐  
源代码网推荐   /// 删除
源代码网推荐  
源代码网推荐   /// </summary>
源代码网推荐  
源代码网推荐   /// <param name="ClassID"></param>
源代码网推荐  
源代码网推荐   /// <returns></returns>
源代码网推荐  
源代码网推荐   [WebMethod]
源代码网推荐  
源代码网推荐   public int CityClassDel(int ClassID)
源代码网推荐  
源代码网推荐   {
源代码网推荐  
源代码网推荐   return CityClassBLLBase.Create_CityClassDelete(ClassID);
源代码网推荐  
源代码网推荐   }
源代码网推荐  
源代码网推荐  
源代码网推荐  
源代码网推荐  }
源代码网推荐  
源代码网推荐    做人要厚道,请注明转自酷网动力(www.ASPCOOL.COM)。
源代码网推荐


源代码网供稿.
网友评论 (0)
会员中心
网络编程
本站推荐
网络编程之精华