惯性聚合 高效追踪和阅读你感兴趣的博客、新闻、科技资讯
阅读原文 在惯性聚合中打开

推荐订阅源

宝玉的分享
宝玉的分享
NISL@THU
NISL@THU
E
Exploit-DB.com RSS Feed
L
LINUX DO - 热门话题
L
Lohrmann on Cybersecurity
K
Kaspersky official blog
Project Zero
Project Zero
Cisco Talos Blog
Cisco Talos Blog
T
The Exploit Database - CXSecurity.com
P
Palo Alto Networks Blog
C
CXSECURITY Database RSS Feed - CXSecurity.com
T
Threatpost
S
Schneier on Security
G
GRAHAM CLULEY
The Hacker News
The Hacker News
T
Threat Research - Cisco Blogs
Scott Helme
Scott Helme
Threat Intelligence Blog | Flashpoint
Threat Intelligence Blog | Flashpoint
P
Privacy & Cybersecurity Law Blog
C
Cyber Attacks, Cyber Crime and Cyber Security
Cyberwarzone
Cyberwarzone
C
CERT Recently Published Vulnerability Notes
T
Tor Project blog
AWS News Blog
AWS News Blog
Simon Willison's Weblog
Simon Willison's Weblog
cs.CL updates on arXiv.org
cs.CL updates on arXiv.org
爱范儿
爱范儿
P
Privacy International News Feed
云风的 BLOG
云风的 BLOG
P
Proofpoint News Feed
S
Securelist
G
Google Developers Blog
The Last Watchdog
The Last Watchdog
Google Online Security Blog
Google Online Security Blog
美团技术团队
F
Fortinet All Blogs
小众软件
小众软件
Recorded Future
Recorded Future
V
Visual Studio Blog
B
Blog RSS Feed
H
Help Net Security
CTFtime.org: upcoming CTF events
CTFtime.org: upcoming CTF events
Google DeepMind News
Google DeepMind News
Blog — PlanetScale
Blog — PlanetScale
博客园 - 聂微东
Stack Overflow Blog
Stack Overflow Blog
Martin Fowler
Martin Fowler
Latest news
Latest news
Spread Privacy
Spread Privacy
H
Heimdal Security Blog

博客园 - winglzz

高手经验谈 招牌net程序员(包吃住有电话,冰箱等)工作地点上海 SQL注入 用asp.net写的论坛程序 ASP.NET中如何防范SQL注入式攻击 .NET 专题-安全-SQL注入攻击 经典的导航二级式导航菜单增强版 asp.net中的联动菜单 ASP.NET中树形图的实现 C#中英文语音合成与中文语音识别技术 ASP.NET实现投票结果的图片进度条显示 几个漂亮的Button的CSS 使用C#在进度条中显示复制文件的进度 Net 下安装、调试的常见问题与错误!!! ASP.NET中的事务处理和异常处理 三层Web体系结构里的两种数据绑定模式 C#实现-移位加密 C#非对称加密程序 C#MD5算法
WEB应用程序中的进度条
winglzz · 2007-03-26 · via 博客园 - winglzz

在前面:

       原文是我在需要使用进度条时找到的一篇文章,讲解详细并附有实例。我在原文的基础上加上了自己的修改:增加了线程处理并且将进度条的使用放到了子线程中处理。这是我第一次翻译文章,敬请各位指正。原文见于http://www.myblogroll.com/Articles/progressbar/,请对照参考。

       谁说在WEB应用程序中不能使用进度条?我认为能。本文将介绍在服务端长时间的处理过程中通过使用进度条提高WEB应用程序的质量和界面友好度。事实上,如果一个WEB应用程序一直运行在无状态和无连接状态下,用户很容易认为事情已经结束了。但是本文介绍的不使用任何ActiveX控件和乱七八糟的Java Applets的进度条将有助于改善这点。

       在一个WEB应用程序中能够使用进度条的关键是浏览器有能力在所有页面加载完之前显示页面。我们将使用这点特性来有步骤的生成并且发送页面给客户端。首先,我们将使用HTML生成一个完美并且漂亮的进度条,然后我们动态的发送Javascript块以更新进度条。当然,以上的所有内容都是在断开用户请求之前实现的。在C#中,Response.Write允许我们加入自定义内容到缓存区并且Response.Fluse()允许我们把所有缓存区中的内容发送到用户的浏览器上。

第一步:

       第一步让我们来建立一个进度条页面,我们使用progressbar.aspx如上所述,我们逐步生成并发送页面到客户端。首先,我们将使用HTML生成一个完美并且漂亮的进度条。所需要的HTML代码我们可以从事先定义的progressbar.htm中获取,所以,第一件事情是装载它并且将数据流发送到客户端的浏览器,在progressbar.aspxPage_Load中加入如下几行:

            string strFileName = Path.Combine( Server.MapPath("./include"), "progressbar.htm" );

         StreamReader sr = new StreamReader( strFileName, System.Text.Encoding.Default );

         string strHtml = sr.ReadToEnd();

         Response.Write( strHtml );

         sr.Close();

         Response.Flush();

     以下是progressbar.htmHTML代码,(译注:作者把脚本函数放在了另外一个js文件中,但我嫌麻烦就也放在了这个静态页面中了)

<script language="javascript">

function setPgb(pgbID, pgbValue)

     if ( pgbValue <= 100 )

     {

         if (lblObj = document.getElementById(pgbID+'_label'))

         {

              lblObj.innerHTML = pgbValue + '%'; // change the label value

         }

         if ( pgbObj = document.getElementById(pgbID) )

         {

              var divChild = pgbObj.children[0];

              pgbObj.children[0].style.width = pgbValue + "%";

         }

         window.status = "数据读取" + pgbValue + "%,请稍候...";

     }

     if ( pgbValue == 100 )

         window.status = "数据读取已经完成";

}

</script>

<html>

     <head>

         <link rel="stylesheet" type="text/css" href="style/common.css" />

     </head>

     <body bgColor="buttonface" topmargin="0" leftmargin="0">

          <table width="100%" height="100%" ID="Table1">

              <tr>

                   <td align="center" valign="middle">

                       <DIV class="bi-loading-status" id="proBar" style="DISPLAY: ; LEFT: 425px; TOP: 278px">

                            <DIV class="text" id="pgbMain_label" align="left"></DIV>

                            <DIV class="progress-bar" id="pgbMain" align="left">

                                 <DIV STYLE="WIDTH:10%"></DIV>

                            </DIV>

                       </DIV>

                   </td>

              </tr>

         </table>

     </body>

</html>

对应的CSS定义如下:

.bi-loading-status {

 /*position:   absolute;*/

 width:        150px;

 padding: 1px;

 overflow: hidden

}

.bi-loading-status .text {

 white-spacenowrap;

 overflow:     hidden;

 width:             100%;

 text-overflow:     ellipsis;

 padding:      1px;

}

.bi-loading-status .progress-bar {

 border:       1px solid ThreeDShadow;

 background:   window;

 height:       10px;

 width:        100%;

 padding: 1px;

 overflow: hidden;

}

.bi-loading-status .progress-bar div {

 background:   Highlight;

 overflow: hidden;

 height:       100%;

 filter     Alpha(Opacity=0, FinishOpacity=100, Style=1, StartX=0, StartY=0, FinishX=100, FinishY=0);

}

第二步:

现在我们可以开始更新进度条了,这是十分重要的部分,因为这部分可以令你的进度条活起来。(译注,原来是使用随机的增加15次直到加载完毕,本文仅使用从1-100的匀速增加,以下内容非译)

首先我们新开一个线程,在Page_Load   中加入以下代码:

         Thread thread = new Thread( new ThreadStart(ThreadProc) );

         thread.Start();

     thread.Join();

在类中增加以下函数:

         private void ThreadProc()

         {

              string strScript = "<script>setPgb('pgbMain','{0}');</script>";

              for ( int i = 0; i <= 100; i++ )

              {

                   System.Threading.Thread.Sleep(10);

                   Response.Write( string.Format( strScript, i ) );

                   Response.Flush();

              }

     }

注意,在以上代码中我们使用for循环,在i每增加一次的情况下往客户端发送一段脚本<script>setPgb('pgbMain','{0}');</script>其中的{0}会被相应的i替换,而该段脚本会调用预先写好的javascript函数setPgb更改页面的进度条状态。