インターネット上には Web の進行状況バーの例が多数ありますが、その多くは推定時間を示しており、タスクの実際の進行状況を正確に反映することはできません。マルチスレッドと ShowModalDialog を組み合わせて、リアルタイムの進行状況バーを作成しました。原理は非常に単純です。スレッドを使用して長期タスクを開始し、セッションを定義し、タスクがさまざまな段階に進むときにセッションの値を変更します。 、ShowModalDialog を使用して、スレッドの開始時にスレッドを開きます。進行状況バー ウィンドウは、セッション値を取得してリアルタイムの進行状況を反映するために常に更新されます。具体的なコードを見てみましょう: (記事の最後にあるソース コードをダウンロードします)
まず、新しい Default.aspx ページを作成します。
クライアント コード:
<body MS_POSITIONING="GridLayout">
<form id="Form1" Method="post" runat="server">
<br>
<br>
<asp:Button id="Button1" runat="server" Text="長いタスクを開始してください!"></asp:Button>
</form>
</body>
サーバー側のコード:
システムを使用する;
System.Collections を使用します。
System.ComponentModel を使用します。
System.Data を使用します。
System.Drawing を使用します。
System.Web を使用します。
System.Web.SessionState を使用します。
System.Web.UI を使用します。
System.Web.UI.WebControls を使用します。
System.Web.UI.HtmlControls を使用します。
System.Text
名前空間 WebProgressBar
を使用します。
{
/**//// <概要>
/// _Default の概要説明。
/// </概要>
パブリック クラス _Default : System.Web.UI.Page
{
protected System.Web.UI.WebControls.Button Button1;
private void Page_Load(オブジェクト送信者、System.EventArgs e)
{
// ページを初期化するためのユーザー コードをここに入力します
デザイナー
が生成したコード#region Web フォーム デザイナーが生成したコード
override protected void OnInit(EventArgs e)
{
//
// CODEGEN: この呼び出しは ASP.NET Web フォーム デザイナに必要です。
//
InitializeComponent();
Base.OnInit(e);
}
/**//// <概要>
/// デザイナーのサポートに必要なメソッド - 変更しないでください
/// このメソッドの内容をコード エディターで表示します。
/// </概要>
private void InitializeComponent()
{
this.Button1.Click += new System.EventHandler(this.Button1_Click);
this.Load += 新しい System.EventHandler(this.Page_Load)
;
#endregion
private void LongTask()
{
//長期的なタスクをシミュレートする
//各ループ シミュレーション タスクは異なるステージに進みます
for(int i=0;i<11;i++)
{
System.Threading.Thread.Sleep(1000);
//現在の進行状況を表示するために各ステージの状態値を設定します
セッション["状態"] = i+1;
}
//タスク終了
Session["State"] = 100;
}
public static void OpenProgressBar(System.Web.UI.Page Page)
{
StringBuilder sbScript = new StringBuilder();
sbScript.Append("<script language='JavaScript' type='text/javascript'>n");
sbScript.Append("<!--n");
//IE5.5以上のサポートが必要
sbScript.Append("window.showModalDialog('Progress.aspx','','dialogHeight: 100px; DialogWidth: 350px; エッジ: 高くなりました; センター: はい; ヘルプ: いいえ; サイズ変更可能: いいえ; ステータス: いいえ; スクロール: いいえ;');n");
//IE5.5以下ではwindow.openを使用してください
//sbScript.Append("window.open('Progress.aspx','', '高さ=100、幅=350、ツールバー=いいえ、メニューバー=いいえ、スクロールバー=いいえ、サイズ変更可能=いいえ、場所=いいえ、ステータス=いいえ');n");
sbScript.Append("// -->n");
sbScript.Append("</script>n");
Page.RegisterClientScriptBlock("OpenProgressBar", sbScript.ToString());
private
void Button1_Click(オブジェクト送信者, System.EventArgs e)
{
System.Threading.Thread thread=new System.Threading.Thread(new System.Threading.ThreadStart(LongTask));
スレッド.スタート();
セッション["状態"]=1;
OpenProgressBar(this.Page);
}
}
}
新しいプログレス バー ページ Progress.aspx を作成する
クライアント:
<base target="_self"> を先頭に追加します
<body MS_POSITIONING="GridLayout">
<form id="Form1" Method="post" runat="server">
<asp:Label id="lblMessages" runat="server"></asp:Label>
<asp:Panel id="panelBarSide" runat="server" width="300px" BorderStyle="Solid" BorderWidth="1px"
ForeColor="シルバー">
<asp:Panel id="panelProgress" runat="server" width="10px" BackColor="Green"></asp:Panel>
</asp:パネル>
<asp:Label id="lblPercent" runat="server" ForeColor="Blue"></asp:Label>
</form>
</body>
サーバー側:
システムを使用する;
System.Collections を使用します。
System.ComponentModel を使用します。
System.Data を使用します。
System.Drawing を使用します。
System.Web を使用します。
System.Web.SessionState を使用します。
System.Web.UI を使用します。
System.Web.UI.WebControls を使用します。
System.Web.UI.HtmlControls
名前空間 WebProgressBar
を使用します。
{
/**//// <概要>
/// 進行状況の概要説明。
/// </概要>
パブリック クラス Progress : System.Web.UI.Page
{
protected System.Web.UI.WebControls.Label lblMessages;
protected System.Web.UI.WebControls.Panel パネル進行状況;
protected System.Web.UI.WebControls.Panel パネルバーサイド;
protected System.Web.UI.WebControls.Label lblPercent;
プライベート int 状態 = 0;
private void Page_Load(オブジェクト送信者、System.EventArgs e)
{
// ページを初期化するためのユーザー コードをここに入力します
if(セッション["状態"]!=null)
{
state = Convert.ToInt32(Session["State"].ToString());
}
それ以外
{
セッション["状態"]=0;
}
if(状態>0&&状態<=10)
{
this.lblMessages.Text = "任務遂行中!";
this.panelProgress.Width = 状態*30;
this.lblPercent.Text = 状態*10 + "%";
Page.RegisterStartupScript("","<script>window.setTimeout('window.Form1.submit()',100);</script>");
}
if(状態==100)
{
this.panelProgress.Visible = false;
this.panelBarSide.Visible = false;
this.lblMessages.Text = "タスクが完了しました!";
Page.RegisterStartupScript("","<script>window.close();</script>");
}
デザイナー
が生成したコード#region Web フォーム デザイナーが生成したコード
override protected void OnInit(EventArgs e)
{
//
// CODEGEN: この呼び出しは ASP.NET Web フォーム デザイナに必要です。
//
InitializeComponent();
Base.OnInit(e);
}
/**//// <概要>
/// デザイナーのサポートに必要なメソッド - 変更しないでください
/// このメソッドの内容をコード エディターで表示します。
/// </概要>
private void InitializeComponent()
{
this.Load += 新しい System.EventHandler(this.Page_Load)
;
#エンドリージョン
}
}
ソースコードのダウンロード: http://justicfu.cnblogs.com/archive/2006/06/29/438433.html