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 }
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 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>
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 }
3 public string unit
4 {
5 get { return (string)ViewState["unit"]; }
6 set { ViewState["unit"] = value; }
7 }
8
9 }
有什么不足之处请大家留言,共同学习。
我的网站 中国机械大全网