jquery ajax .net使用

jquery是一个优秀的javascript框架,大大提高了javascript代码的简洁性,同时也降低了javascript的难度。关于具体的jquery函数请参考http://www.cnblogs.com/greatxj/articles/2260357.html。对于jquery中的ajax,我主要使用了ajax()这个函数,下面就写一点使用心得,有什么不足之处向大家多多请教了。后台代码为C#

1.对一个表添加数据

前台代码

 1   $.ajax({
 2                     type: "POST",   //访问WebService使用Post方式请求
 3                     contentType: "application/json"//WebService 会返回Json类型
 4                     url: "ajax.aspx/AddToTP"//调用WebService的地址和方法名称组合 ---- WsURL/方法名
 5                     data: '{  tid: "' + tid + '", uid:"' + uid + '",score: "' + score + '", degree: "' + degree + '"}',         //这里是要传递的参数,格式为 data: "{paraName:paraValue}",下面将会看到       
 6                     dataType: 'json',
 7                     success: function (result) {     //回调函数,result,返回值
 8                         alert(result.d);//弹出ajax请求成功后,后台的返回值
 9                         if (result.d == "success") {
10 
11                       //成功事件
12                         }
13                     }

14                 });  

c#接收ajax请求可以用.aspx,或者.ashx(一般事务处理程序) ,这里使用.aspx中的web服务。

 

1     [System.Web.Services.WebMethod()]
2     public static string AddToTP(string tid,string uid,string score,string degree)
3     {
4         bool ok=DBHpler.ExecuteNonQueryTwo( "Insert into trainingpeople (tid,uid,score,degree) Values('"+tid+"','"+uid+"','"+score+"','"+degree+"')");//使用sql帮助类,对表trainingpeople插入数据
5         if (ok == true) { return "success"; }  //对DBHpler.ExecuteNonQueryTwo返回值判断
6         else { return "failed"; }
7     } 

2.当用户点击按钮时,ajax请求返回用户选择班级的人员表单,并对表单格式化,此处模拟的为对班级测试输入成绩,用户可选择直接输入分数,或者是二级制

前台js代码

  <script language="javascript" type="text/javascript">

   
      function getPeople() {
          $('#progress').css('visibility''visible');  //loading图片显示
              $.ajax({
                  type: "POST",   //访问WebService使用Post方式请求
                  contentType: "application/json"//WebService 会返回Json类型
                  url: "ajax.aspx/GetPeople"//调用WebService的地址和方法名称组合 ---- WsURL/方法名
                  data: '{unit:"' + $('#Select1').val() + '"}',         //这里是要传递的参数为用户下拉框中选择的值,此处为用户选择的某个子单位      
                  dataType: 'json',
                  success: function (data) {     //回调函数,result,返回值
                      $('.dd').empty();         //对<div class="dd">清空
                      $('.dd').append(data.d);         //对<div class="dd">填写ajax返回值
                      
                      $('#progress').css('visibility''hidden');   //loading图片隐藏
                      var ss = $('#Select3 option:selected').val();
                      //根据用户选择的值格式化表单
                      if (ss == "score") {
                          $('.dd .scoretxt').each(function (i) {
                              $($('.dd .scoretxt ')[i]).append('<input type="text" class="score"/>');
                          });

                      }
                      else {
                     
                              $('.dd .scoretxt').each(function (i) {
                                  $($('.dd .scoretxt ')[i]).append('<select class="score" ><option value="合格">合格</option><option value="不合格">不合格</option><option value="未测">未测</option></select>');
                              });

                      }

                  }
              });
          }
 </script>

 

后台代码

 ajax.aspx中

  •    [System.Web.Services.WebMethod()]
  •      public static string GetPeople(string unit)
  •      {
  •          System.Threading.Thread.Sleep(500); //延迟0.5秒
  •          Page page = new Page();
  •          UserScoreInput ctl = (UserScoreInput)page.LoadControl("~\\Samples\\UserScoreInput.ascx");  //加载表单控件
  •          ctl.unit = unit;  //传递给表单控件的参数
  •       
  •             page.Controls.Add(ctl);
  •          System.IO.StringWriter writer = new System.IO.StringWriter();
  •          HttpContext.Current.Server.Execute(page, writer, false);
  •          string output = writer.ToString();
  •          writer.Close();
  •          return output;

15     } 

用户控件 

 

UserScoreInput.ascx代码
 1 <%@ Control Language="C#" AutoEventWireup="true"  Inherits="UserScoreInput"  ClassName="UserScoreInput" %>
 2 
 3 <script runat="server">
 4     protected override void OnLoad(EventArgs e)
 5     {
 6       
 7 
 8         if (int.Parse(this.unit) > 1000)
 9             sqlDsOrders.SelectCommand = "SELECT [ID], [name] FROM [personnel] WHERE unit = '" + this.unit + "%'";
10 
11         base.OnLoad(e);
12     }
13 
14    
15 </script>
16 //此处采用两列重复
17 <asp:SqlDataSource ID="sqlDsOrders" runat="server" ConnectionString="<%$ ConnectionStrings:ConnectionString %>" >
18 </asp:SqlDataSource>
19 <asp:Repeater ID="List" DataSourceID="sqlDsOrders" runat="server">
20     <HeaderTemplate>
21         <table style="width:80%">
22         <tr>
23 <th>姓名</th>
24 <th>成绩</th>
25 <th>姓名</th>
26 <th>成绩</th>
27 </tr>
28     </HeaderTemplate>
29     <ItemTemplate>
30         <tr>
31              <td style="width:25%">
32              <div class="hh" ><%# Eval("name") %></div>
33              </td>
34               <td style="width:25%">
35              <div class="scoretxt" name='<%# Eval("id") %>'>
36              </td>
37     
38     </ItemTemplate>
39       <AlternatingItemTemplate>
40        
41              <td style="width:25%">
42              <div class="hh" ><%# Eval("name") %></div></td>
43 
44               <td style="width:25%">
45              <div class="scoretxt" name='<%# Eval("id") %>'>
46              </td>
47       </tr>
48         </AlternatingItemTemplate>
49     <FooterTemplate>
50         </table>
51     </FooterTemplate>

52 </asp:Repeater> 

 UserScoreInput.ascx.cs代码

 1 public partial class UserScoreInput : UserControl

2 {
3     public string unit
4     {
5         get { return (string)ViewState["unit"]; }
6         set { ViewState["unit"] = value; }
7     }
8    
9 }

 有什么不足之处请大家留言,共同学习。

我的网站 中国机械大全网

posted on 2012-04-18 15:45  水行者  阅读(414)  评论(0编辑  收藏  举报

导航