令你心動的Asp.net 開發中的MessageBox控制項

來源:互聯網
上載者:User
asp.net|控制項 令你心動的Asp.net 開發中的MessageBox控制項

相信使用ASP.NET做Web開發的程式員們,都會懷念使用MessageBox.Show( “” )的資訊提示方式吧。只可惜在ASPX中並不支援此類功能函數,至多也就是在指令碼中使用alert( “ ” )來達到目的。要是想在伺服器端的代碼中來控制用戶端資訊提示表單的顯示,就不能直接進行控制了。
以下就是我所設計開發的一個用於在伺服器端來控制用戶端資訊提示表單顯示的Web自訂控制項,很好用哦!
它的操作非常簡單,代碼也很少,相信您對它的使用會感到滿意的!
您只需在伺服器端的代碼中對該控制項的Text屬性進行設定,就可以在用戶端看到您所需要資訊提示表單,更為理想的是該Text屬性為無狀態屬性,也就是說在下一次的回傳過程中無需再對它進行操作就能自動實現隱藏。
簡單地說,您只需要在要求顯示的時候對Text屬性進行賦值就可達到目的,不對它進行賦值就能實現自動隱藏。
而且還有一點您應該注意的是該控制項在aspx頁面中的位置,一般情況下建議置於頁面未尾位置,這樣就可以在所有內容都顯示出來以後才跳出資訊提示對話方塊,否則置於該控制項後面的其它頁面內容都將被暫時隱藏。
以下為該控制項的原始碼列表:

//********************************************
using System;
using System.Web.UI;
using System.Web.UI.WebControls;
using System.ComponentModel;

namespace BasicWebControl.MessageBox
{
     /// <summary>
     /// AlertBox 的摘要說明。
     /// </summary>
     [DefaultProperty("Text"), ToolboxData("<{0}:AlertBox runat=server></{0}:AlertBox>")]
     public class AlertBox : System.Web.UI.Control
     {
         private string     text = string.Empty     ;
    
         /// <summary>
         /// 顯示的內容,注意不能包含單、雙引號
         /// </summary>
         [Bindable(true),Category("Appearance"),DefaultValue("")]
         public string Text
         {
              get
              {
                   return text;
              }

              set
              {
                   text = value;
              }
         }

         /// <summary>
         ///
         /// </summary>
         public AlertBox()
         {            
         }

         /// <summary>
         /// 將此控制項呈現給指定的輸出參數。
         /// </summary>
         /// <param name="output"> 要寫出到的 HTML 編寫器 </param>
         protected override void Render(HtmlTextWriter output)
         {
              if( Text != string.Empty )
              {
                   output.Write( "<script language='javascript'>alert('" );
                   output.Write(Text);
                   output.Write("');</script>");
              }
         }
     }
}
//********************************************

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.