首 页 | 精品电影 | 音乐天堂 | 在线游戏 | Flash MTV | 三湘书屋 | 幽默笑话 | 三湘图库 | 美女写真 | IT知识库 | QQ贴图 | 加入书签

网页制作网络编程图形图象操作系统冲浪宝典软件教学网络安全认证考试通信技术电子商务业内动态书籍教程原码

最近更新 文章分类 多媒体类 精品软件

本站搜索:
您的位置:三湘时空 -> IT知识库 -> 文章分类 -> ASP.NET技巧 -> ASP.NET 2.0 正式版中无刷新页面的开发(示例代码的补充)
ASP.NET 2.0 正式版中无刷新页面的开发(示例代码的补充)


文章类别:ASP.NET技巧 来源: 作者: 发表日期:2006-4-5 字体:[ ]

小游戏 | 在线影院 | 幽默笑话 | 源码下载 | Flash MTV | 音乐试听 | 书屋 | 美女写真

原文请见Leon.Zhou的:http://pfzhou.cnblogs.com/archive/2006/03/31/363342.html

下载了示例代码,并转换成VB了,AJAX功能测试成功。但遇到些小问题:
Demo1很正常。
Demo2按Leon原来的写法testAJAX.aspx.vb中Line 22不成功。所以我直接在IDE环境中,修改button3的OnClientClick属性,见testAJAX.asp的Line 52。测试成功。
Demo3按原来的加入客户端属性无法成功,在testAJAX.aspx.vb中第20行并未起作用。不知道是什么原因。  因此我只有加上一个button3来引发客户端事件。
这是个很好的例子,值得学习,详细原理说明请见作者的原文。测试时,请在您项目的web.config中添加<add name="NorthWind" connectionString="...相应的数据库连接串...">
testAJAX.aspx

 1<%@ Page Language="VB" AutoEventWireup="false" CodeFile="testAJAX.aspx.vb" Inherits="testAJAX" %>
 2
 3<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
 4
 5<html xmlns="http://www.w3.org/1999/xhtml" >
 6<head id="Head1" runat="server">
 7    <title>ASP.NET 2.0 页面提交无刷新演示</title>
 8    <script type="text/javascript" language ="javascript">
 9       Function CallServer1()function CallServer1(inputcontrol, context)
10       {
11            context.innerHTML = "<IMG SRC='images/pie.gif' />Loading";
12            arg = 'ServerMethod1|' + inputcontrol.value;
13            <%= ClientScript.GetCallbackEventReference(Me, "arg", "ReceiveServerData1", "context")%>;
14        }
15       
16        Function ReceiveServerData1()function ReceiveServerData1(result, context)
17        {
18            context.innerHTML = context.id + ":" + result;
19        }
20       
21        Function CallServer2()function CallServer2(obj)
22        {
23            context = gridspan;
24            context.innerHTML = "<IMG SRC='images/pie.gif' />数据加载中";
25            arg = "ServerMethod2|" + obj.value;
26            <%= ClientScript.GetCallbackEventReference(Me, "arg", "ReceiveServerData2", "context")%>;
27        }
28       
29        Function ReceiveServerData2()function ReceiveServerData2(result, context)
30        {
31            context.innerHTML = result;
32        }
33       
34    </script>
35</head>
36<body>
37    <form id="form1" runat="server">
38    <div>
39        <h1>Demo1:html按钮提交数据</h1><br />
40        <asp:TextBox ID="TextBox1" runat="server"></asp:TextBox>
41        <input id="Button1" type="button" value="提交到Label1" onclick="CallServer1(TextBox1, Label1)"/>&nbsp;
42        <input id="Button2" type="button" value="提交到Label2" onclick="CallServer1(TextBox1, Label2)"/>
43        <br />
44        <asp:Label ID="Label1" runat="server" Text="Label1:"></asp:Label>
45        <br />
46        <asp:Label ID="Label2" runat="server" Text="Label2:"></asp:Label>
47    </div>
48    <hr />
49    <div>
50        <h1>Demo2:服务器按钮提交数据</h1><br />
51        <asp:TextBox ID="TextBox2" runat="server"></asp:TextBox>
52        <asp:Button ID="Button3" runat="server" Text="Button" OnClientClick="CallServer1(TextBox2, Label3);return false;" /><br />
53        <asp:Label ID="Label3" runat="server" Text="Label3:"></asp:Label></div>   
54    <hr />
55    <div>
56        <h1>Demo3:下拉列表框和gridview绑定数据</h1><br />
57        <asp:SqlDataSource ID="SqlDataSource1" runat="server" ConnectionString="<%$ connectionStrings:NorthWind %>"
58            SelectCommand="select distinct(country) from customers"></asp:SqlDataSource>
59        <asp:SqlDataSource ID="SqlDataSource2" runat="server" ConnectionString="<%$ connectionStrings:NorthWind %>"
60            SelectCommand="select customerid, companyname, country from customers where country=@Country">
61            <SelectParameters>
62                <asp:ControlParameter Name="Country" ControlID="DropDownList1" PropertyName="SelectedValue" />
63            </SelectParameters>
64        </asp:SqlDataSource>
65        <div>
66            <asp:DropDownList ID="DropDownList1" runat="server" Width="239px"
67                DataSourceID="SqlDataSource1" DataTextField="Country" DataValueField="Country">
68            </asp:DropDownList>
69            <input id="Button4" type="button" value="刷新" onclick="CallServer2(DropDownList1)"/>
70        </div>
71        <br />
72        <span id="gridspan">
73            <asp:GridView ID="GridView1" runat="server" DataSourceID="SqlDataSource2" CellPadding="4" ForeColor="#333333" GridLines="None">
74                <FooterStyle BackColor="#990000" Font-Bold="True" ForeColor="White" />
75                <RowStyle BackColor="#FFFBD6" ForeColor="#333333" />
76                <SelectedRowStyle BackColor="#FFCC66" Font-Bold="True" ForeColor="Navy" />
77                <PagerStyle BackColor="#FFCC66" ForeColor="#333333" HorizontalAlign="Center" />
78                <HeaderStyle BackColor="#990000" Font-Bold="True" ForeColor="White" />
79                <AlternatingRowStyle BackColor="White" />
80            </asp:GridView>
81        </span>
82    </div>
83    </form>
84</body>
85</html>
86
testAJAX.aspx.vb
 1
 2Imports System
 3Imports System.Data
 4Imports System.Configuration
 5Imports System.Web
 6Imports System.Web.Security
 7Imports System.Web.UI
 8Imports System.Web.UI.WebControls
 9Imports System.Web.UI.WebControls.WebParts
10Imports System.Web.UI.HtmlControls
11Imports System.IO
12Imports System.Globalization
13
14Partial Public Class testAJAXClass testAJAX
15    Inherits System.Web.UI.Page
16    Implements ICallbackEventHandler
17    Protected Sub Page_Load()Sub Page_Load(ByVal sender As Object, ByVal e As EventArgs)
18        '注册客户端事件处理方法
19        '似乎这句并没起作用,因此我别外加了一个button4来引发客户端事件  by AndyDavis
20        DropDownList1.Attributes.Add("onchange", "CallServer2(this)")
21        'Button3的客户端事件可以直接在IDE中OnClientClick属性中设置,不需要在这里添加  by AndyDavis
22        'Button3.Attributes.Add("onclick", "CallServer1(TextBox2, Label3);return false;")
23    End Sub
24
25    Private serverReturn As String
26
27    Public Function GetCallbackResult()Function GetCallbackResult() As String Implements ICallbackEventHandler.GetCallbackResult
28        '为便于查看加载效果,添加延时
29        System.Threading.Thread.Sleep(2000)
30
31        Dim parts() As String = serverReturn.Split("|"c)
32        '根据传递的方法名进行调用,并传递相应的参数,目前只支持一个参数
33        Return CStr([GetType]().GetMethod(parts(0)).Invoke(Me, New Object() {parts(1)}))
34    End Function
35
36
37    Public Sub RaiseCallbackEvent()Sub RaiseCallbackEvent(ByVal eventArgument As String) Implements ICallbackEventHandler.RaiseCallbackEvent
38        serverReturn = eventArgument
39    End Sub
40
41    '根据从客户端传来的英文国家名或缩写,翻译成相应的中文国家名
42    Public Function ServerMethod1()Function ServerMethod1(ByVal arg As String) As String
43        Dim s As String = ""
44        Select Case arg.ToLower()
45            Case "cn"
46            Case "china"
47                s = "中国"
48                Exit Select
49            Case "us"
50                s = "美国"
51                Exit Select
52            Case Else
53                s = "未知国家"
54                Exit Select
55        End Select
56        Return s
57    End Function
58
59    '根据从客户端传来的值,对GridView的内容进行更新,并将更新后的GridView的html返回
60    Public Function ServerMethod2()Function ServerMethod2(ByVal arg As String) As String
61        DropDownList1.SelectedValue = arg
62        GridView1.DataBind()
63
64        Return RenderControl(GridView1)
65    End Function
66
67    Private Overloads Function RenderControl()Function RenderControl(ByVal control As Control) As String
68        Dim writer1 As StringWriter = New StringWriter(CultureInfo.InvariantCulture)
69        Dim writer2 As HtmlTextWriter = New HtmlTextWriter(writer1)
70
71        control.RenderControl(writer2)
72        writer2.Flush()
73        writer2.Close()
74
75        Return writer1.ToString()
76    End Function
77End Class
78

上一篇:Acdsee视频教程3 下一篇:c#摄氏华氏转换
本栏目热门文章
·如何实现无刷新的DropdownList联动效果 2005-10-4
·使用HttpWebRequest向网站模拟上传数据 2005-10-4
·当DataSet中包含主/子表时,Update更新步骤 2005-10-6
·ASP.NET2.0实现无刷新客户端回调 2005-11-13
·ASP.NET中文件上传下载方法集合 2006-5-28
·分享个极好的无刷新二级联动下拉列表,同样适用与firefox 2005-10-19
·在Web DataGrid中当鼠标移到某行与离开时行的颜色发生改变( 2005-10-4
·ASP.NET中实现Flash与.NET的紧密集成 2005-11-21
·关于Asp.net页面Page_Load被执行两次的问题 2005-10-4
·ASP.NET极限:页面导航 (翻译) 2005-10-8
新近更新文章
·在VS2003中直接用DREAMWEAVER8打开ASPX文件 2006-6-22
·asp.net2.0中异步调用WebService(异步页) 2006-6-22
·ASP.NET2.0数据库入门之常见错误 2006-6-22
·ASP.NET 2.0中XSLT的使用 2006-6-22
·.Net2.0 使用ConfigurationManager读写配置 2006-6-22
·.net 做的IP 访问限制 2006-6-22
·ASP.Net2.0 GridView 多列排序,显示排序图标,分页 2006-6-22
·数据岛出到Excel最为简易的方法 2006-6-20
·权限树中Checkbox的操作[Asp.Net2.0] 2006-6-20
·使用Data Access Application Block 得到 2006-6-20
首 页 | 软件发布 | 广告联系 | 下载帮助 | 意见反馈 | 网站地图
  CopyRight? 2002-2004 WWW.SXSKY.NET? All Rights Reserved
三湘时空 站长QQ:82675303 Email: