在asp.net中,有时候页面加载时,后台需要进行一些操作,比如查询数据库等。而且可能这些操作需要花费较长时间,致使前台长时间无响应,甚至有可能造成页面超时。可以采用以下方法解决:
1、asp.net 1.1
2、asp.net 2.0
在asp.net2.0的代码中采用了异步页,实现效率提高了。但是有一点不明白,一定要循环3次以上(while(i<3))前台才会显示“正在读取数据请稍候...”.
1、asp.net 1.1
1
using System.Web.UI;
2
using System.Web.UI.WebControls;
3
using System.Web.UI.WebControls.WebParts;
4
using System.Web.UI.HtmlControls;
5
using System.Threading;
6
public partial class Default2 : System.Web.UI.Page
7
{
8
private int vlue = 0;
9
protected void Page_Load(object sender, EventArgs e)
10
{
11
Thread td = new Thread(new ThreadStart(BindData));
12
td.Start();
13
WritePress();
14
//BindData();
15
}
16
private void WritePress()
17
{
18
int i = 0;
19
while (vlue == 0)
20
{
21
22
Response.Write("<table id='s" + i + "' width='100%'><tr ><td></td><td align=center >正在读取数据请稍候
.</td></tr></table>");
23
if (i > 0)
24
{
25
Response.Write("<script>document.getElementById('s" + (i - 1) + "').style.display ='none';</script>");
26
}
27
i = i + 1;
28
Response.Flush();
29
30
}
31
Response.Write("<script>document.getElementById('s" + (i - 1) + "').style.display ='none';</script>");
32
}
33
public void BindData()
34
{
35
dsOrders DSO = new dsOrders();
36
DSO.Orders.AddOrdersRow("zp", "1", DateTime.Now, DateTime.Now, DateTime.Now, "s", "t", "sz");
37
GridView1.DataSource = DSO;
38
GridView1.DataBind();
39
Thread.Sleep(700);
40
vlue = 1;
41
}
42
}

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22


23

24

25

26

27

28

29

30

31

32

33

34

35

36

37

38

39

40

41

42

2、asp.net 2.0
1
using System;
2
using System.Data;
3
using System.Configuration;
4
using System.Web;
5
using System.Web.Security;
6
using System.Web.UI;
7
using System.Web.UI.WebControls;
8
using System.Web.UI.WebControls.WebParts;
9
using System.Web.UI.HtmlControls;
10
using System.Threading;
11
public partial class _Default : System.Web.UI.Page
12
{
13
private AsyncDelegateGetDataSet dgs;
14
private int i = 0;
15
16
protected void Page_Load(object sender, EventArgs e)
17
{
18
PageAsyncTask task = new PageAsyncTask(
19
new BeginEventHandler(BeginAsyncOperation),
20
new EndEventHandler(EndAsyncOperation),
21
new EndEventHandler(TimeoutAsyncOperation),
22
null
23
);
24
RegisterAsyncTask(task);
25
WritePress();
26
}
27
public void BindData()
28
{
29
dsOrders DSO = new dsOrders();
30
DSO.Orders.AddOrdersRow("zp", "1", DateTime.Now, DateTime.Now, DateTime.Now, "s", "t", "sz");
31
GridView1.DataSource = DSO;
32
GridView1.DataBind();
33
Thread.Sleep(3000);
34
}
35
IAsyncResult BeginAsyncOperation(object sender, EventArgs e,
36
AsyncCallback cb, object state)
37
{
38
39
dgs=new AsyncDelegateGetDataSet(BindData);
40
return dgs.BeginInvoke(cb, state);
41
}
42
void EndAsyncOperation(IAsyncResult ar)
43
{
44
Response.Write("<script>document.getElementById('s" + (i - 1) + "').style.display ='none';</script>");
45
dgs.EndInvoke(ar);
46
}
47
void TimeoutAsyncOperation(IAsyncResult ar)
48
{ }
49
private void WritePress()
50
{
51
while (i<3)
52
{
53
54
Response.Write("<table id='s" + i + "' width='100%'><tr ><td></td><td align=center >正在读取数据请稍候
.</td></tr></table>");
55
if (i > 0)
56
{
57
Response.Write("<script>document.getElementById('s" + (i - 1) + "').style.display ='none';</script>");
58
}
59
i = i + 1;
60
Response.Flush();
61
62
}
63
}
64
65
}
66
public delegate void AsyncDelegateGetDataSet();

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

23

24

25

26

27

28

29

30

31

32

33

34

35

36

37

38

39

40

41

42

43

44

45

46

47

48

49

50

51

52

53

54


55

56

57

58

59

60

61

62

63

64

65

66

在asp.net2.0的代码中采用了异步页,实现效率提高了。但是有一点不明白,一定要循环3次以上(while(i<3))前台才会显示“正在读取数据请稍候...”.
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· AI与.NET技术实操系列:基于图像分类模型对图像进行分类
· go语言实现终端里的倒计时
· 如何编写易于单元测试的代码
· 10年+ .NET Coder 心语,封装的思维:从隐藏、稳定开始理解其本质意义
· .NET Core 中如何实现缓存的预热?
· 25岁的心里话
· 闲置电脑爆改个人服务器(超详细) #公网映射 #Vmware虚拟网络编辑器
· 零经验选手,Compose 一天开发一款小游戏!
· 通过 API 将Deepseek响应流式内容输出到前端
· 因为Apifox不支持离线,我果断选择了Apipost!