在ASP.NET的服务器端使用message box(Message box Server side in ASP.Net)

 

ASP.NET的服务器端使用message box(Message box Server side in ASP.Net)

                                           作者: R.Arockia Jayaseelan :涟漪勇

Message Box是用于显示消息的对话框,等待用户选择上面的不同按钮来执行不同的程序.完成了用户与程序的交互,在我们些windows程序是可以很容易的实现这个功能并且来自定义它,可是对于web程序就没有那么容易了,当然,可以JavaScript来实现这些功能.但是它不可以自己定义按钮的类型在对话框上.

 JavaScript你可以访问Message Box在页面载入和回送时,利用JavaScript你的程序没有办法得到用户的确认信息,为了实现的到用户选择的确认信息,你必须有服务器端的Message Box.

服务器端的Message Box提供用户选择不同的条件,这些条件是根据程序来的,例如确定或者取消, 得到用户的确认选择后我们来控制我们的程序执行不同的段落.

 

下面是运行是的效果图

 

AJSMessageBox_2.jpg

下面是实现的代码
1. MessageBox.vb(Class) emembarrassed.gif
Imports System Imports System.Web Imports System.Web.UI Imports System.Web.UI.WebControls Imports System.Web.UI.HtmlControls Imports System.IO Imports System.Drawing Imports System.Drawing.Imaging Imports System.Drawing.Drawing2D Public Class js Public Function js() End Function End Class Public Class MessageBox Inherits WebControl Private strLeft As String Private strTop As String Private intButton As Integer Private strMessage As String Private strTitle As String Private strImage As String Private strCss As String Private strCssTitle As String Private strCssMessage As String Private strButtonYes As String Private strButtonNo As String Private strButtonCancel As String Private strButtonWidth As Integer Private strMessageBoxIDYes As String Private strMessageBoxIDNo As String Private strMessageBoxIDCancel As String Private intMessageBoxWidth As Integer Private intMessageBoxHeight As Integer Private intMessageBoxImageWidth As Integer Private intMessageBoxImageHeight As Integer Dim homedirectory As String ' Message box left position Public Property MessageBoxLeft() As String Get Return strLeft End Get Set(ByVal Value As String) strLeft = Value End Set End Property ' Message box top position Public Property MessageBoxTop() As String Get Return strTop End Get Set(ByVal Value As String) strTop = Value End Set End Property ' Number of buttons you want to display in the message box Public Property MessageBoxButton() As Integer Get Return intButton End Get Set(ByVal Value As Integer) intButton = Value End Set End Property ' Customize message you want to display in the message box Public Property MessageBoxMessage() As String Get Return strMessage End Get Set(ByVal Value As String) strMessage = Value End Set End Property ' Title you want to display in the message box Public Property MessageBoxTitle() As String Get Return strTitle End Get Set(ByVal Value As String) strTitle = Value End Set End Property ' Image you want to display in the message box (like information / warning) Public Property MessageBoxImage() As String Get Return strImage End Get Set(ByVal Value As String) strImage = Value End Set End Property ' Message box ID for Yes button Public Property MessageBoxIDYes() As String Get Return strMessageBoxIDYes End Get Set(ByVal Value As String) strMessageBoxIDYes = Value End Set End Property ' Message box ID for No button Public Property MessageBoxIDNo() As String Get Return strMessageBoxIDNo End Get Set(ByVal Value As String) strMessageBoxIDNo = Value End Set End Property ' Message box ID for Cancel button Public Property MessageBoxIDCancel() As String Get Return strMessageBoxIDCancel End Get Set(ByVal Value As String) strMessageBoxIDCancel = Value End Set End Property ' Style you want to incorporate for message box Public Property MessageBoxCss() As String Get Return strCss End Get Set(ByVal Value As String) strCss = Value End Set End Property Public Property MessageBoxCssTitle() As String Get Return strCssTitle End Get Set(ByVal Value As String) strCssTitle = Value End Set End Property Public Property MessageBoxCssMessage() As String Get Return strCssMessage End Get Set(ByVal Value As String) strCssMessage = Value End Set End Property ' Message box Text for Yes button Public Property MessageBoxButtonYesText() As String Get Return strButtonYes End Get Set(ByVal Value As String) strButtonYes = Value End Set End Property ' Message box Text for No button Public Property MessageBoxButtonNoText() As String Get Return strButtonNo End Get Set(ByVal Value As String) strButtonNo = Value End Set End Property ' Message box Text for Cancel button Public Property MessageBoxButtonCancelText() As String Get Return strButtonCancel End Get Set(ByVal Value As String) strButtonCancel = Value End Set End Property ' Message box buttons width Public Property MessageBoxButtonWidth() As Integer Get Return strButtonWidth End Get Set(ByVal Value As Integer) strButtonWidth = Value End Set End Property ' Message box width Public Property MessageBoxWidth() As Integer Get Return intMessageBoxWidth End Get Set(ByVal Value As Integer) intMessageBoxWidth = Value End Set End Property ' Message box height Public Property MessageBoxHeight() As Integer Get Return intMessageBoxHeight End Get Set(ByVal Value As Integer) intMessageBoxHeight = Value End Set End Property ' Message box image width Public Property MessageBoxImageWidth() As Integer Get Return intMessageBoxImageWidth End Get Set(ByVal Value As Integer) intMessageBoxImageWidth = Value End Set End Property ' Message box image height Public Property MessageBoxImageHeight() As Integer Get Return intMessageBoxImageHeight End Get Set(ByVal Value As Integer) intMessageBoxImageHeight = Value End Set End Property Protected Friend layer As HtmlGenericControl Protected Friend ilayer As HtmlGenericControl Protected Friend img As HtmlGenericControl Protected Friend div As HtmlGenericControl Protected Friend ButtonOK As Button Protected Friend ButtonYes As Button Protected Friend ButtonNo As Button Protected Friend ButtonCancel As Button Protected Alertimage As System.Web.UI.WebControls.Image Public Sub New() MyBase.New("div") End Sub Protected Overrides Sub OnInit(ByVal e As EventArgs) MyBase.OnInit(e) ' Default properties settings for message box control If strLeft Is Nothing Then strLeft = "250" End If If strTop Is Nothing Then strTop = "250" End If If strTitle Is Nothing Then strTitle = "MessageBox" End If If intButton < 0 Then intButton = 1 End If If strMessageBoxIDYes Is Nothing Then strMessageBoxIDYes = "MessageBoxIDYes" End If If strMessageBoxIDNo Is Nothing Then strMessageBoxIDNo = "MessageBoxIDNo" End If If strMessageBoxIDCancel Is Nothing Then strMessageBoxIDCancel = "MessageBoxIDCancel" End If If strCss Is Nothing Then strCss = "" End If If strCssMessage Is Nothing Then strCssMessage = "" End If If strCssTitle Is Nothing Then strCssTitle = "" End If If strMessage Is Nothing Then strMessage = "No message to display here." End If If intButton = 1 Or intButton > 3 Or intButton < 1 Then If strButtonYes Is Nothing Then strButtonYes = "OK" End If ElseIf intButton > 1 And intButton < 4 Then If strButtonYes Is Nothing Then strButtonYes = "Approve" End If If strButtonNo Is Nothing Then strButtonNo = "Cancel" End If If strButtonCancel Is Nothing Then strButtonCancel = "Ignore" End If End If If strButtonWidth < 5 Then strButtonWidth = 70 End If If intMessageBoxWidth < 10 Then intMessageBoxWidth = 250 End If If intMessageBoxHeight < 1 Then intMessageBoxHeight = 8 End If If intMessageBoxImageWidth < 5 Then intMessageBoxImageWidth = 36 End If If intMessageBoxImageHeight < 5 Then intMessageBoxImageHeight = 36 End If If homedirectory Is Nothing Then homedirectory = Me.Page.Request.PhysicalApplicationPath End If End Sub Protected Overrides Sub createChildControls() ' Creating message box Dim myRow As TableRow Dim myCell As TableCell Dim myTable As Table = New Table myTable.BorderWidth = New Unit(0) myTable.CellSpacing = 0 myTable.Width = New Unit(intMessageBoxWidth) myTable.Height = New Unit(intMessageBoxHeight) Controls.Add(myTable) myRow = New TableRow myRow.BorderWidth = New Unit(0) myTable.Rows.Add(myRow) myCell = New TableCell Dim NewLabel As Label = New Label NewLabel.Text = strTitle NewLabel.CssClass = strCssTitle myCell.Controls.Add(NewLabel) myCell.ID = "dragbar" myCell.ColumnSpan = 5 myCell.CssClass = strCssTitle If strCssTitle = "" Then myCell.ForeColor = System.Drawing.Color.White myCell.BackColor = System.Drawing.Color.DarkBlue myCell.Font.Name = "Verdana" myCell.Font.Bold = True myCell.Font.Size = New FontUnit(8) myCell.Style.Add("CURSOR", "hand") End If myRow.Cells.Add(myCell) myRow = New TableRow myRow.BorderWidth = New Unit(0) myTable.Rows.Add(myRow) myCell = New TableCell myCell.ColumnSpan = 5 myCell.CssClass = strCssMessage If strCssMessage = "" Then myCell.BackColor = System.Drawing.Color.LightGray End If myRow.Cells.Add(myCell) Dim myRow1 As TableRow Dim myCell1 As TableCell Dim myTable1 As Table = New Table myTable1.BorderWidth = New Unit(0) myTable1.CellSpacing = 0 myCell.Controls.Add(myTable1) myRow1 = New TableRow myRow1.BorderWidth = New Unit(0) myTable1.Rows.Add(myRow1) myCell1 = New TableCell myCell1.CssClass = strCssMessage myCell1.BorderWidth = New Unit(0) myCell1.Width = New Unit(36) Dim Alertimage As System.Web.UI.WebControls.Image = New System.Web.UI.WebControls.Image Alertimage.Height = New Unit(intMessageBoxImageHeight) Alertimage.Width = New Unit(intMessageBoxImageWidth) Alertimage.BorderWidth = New Unit(0) Alertimage.ImageUrl = strImage myCell1.Controls.Add(Alertimage) myRow1.Cells.Add(myCell1) myCell1 = New TableCell myCell1.CssClass = strCssMessage myCell1.BorderWidth = New Unit(0) myCell1.CssClass = strCssMessage If strCssMessage = "" Then myCell1.HorizontalAlign = HorizontalAlign.Center myCell1.ForeColor = System.Drawing.Color.Black myCell1.BackColor = System.Drawing.Color.LightGray myCell1.BorderColor = System.Drawing.Color.LightGray myCell1.Font.Name = "Verdana" myCell1.Font.Bold = True myCell1.Font.Size = New FontUnit(8) End If Dim NewLabel1 As Label = New Label NewLabel1.Text = strMessage myCell1.Controls.Add(NewLabel1) myRow1.Cells.Add(myCell1) myRow = New TableRow myRow.BorderWidth = New Unit(0) myTable.Rows.Add(myRow) If intButton = 1 Or intButton > 3 Or intButton < 1 Then myCell = New TableCell myCell.ColumnSpan = 5 myCell.BorderWidth = New Unit(0) myCell.CssClass = strCssMessage myCell.HorizontalAlign = HorizontalAlign.Center If strCssMessage = "" Then myCell.ForeColor = System.Drawing.Color.Black myCell.BackColor = System.Drawing.Color.LightGray myCell.Font.Name = "Verdana" myCell.Font.Bold = True myCell.Font.Size = New FontUnit(8) End If ButtonOK = New Button ButtonOK.ID = strMessageBoxIDYes ButtonOK.Text = strButtonYes ButtonOK.Width = New Unit(strButtonWidth) ButtonOK.Style.Add("CURSOR", "hand") myCell.Controls.Add(ButtonOK) myRow.Cells.Add(myCell) End If If intButton > 1 And intButton < 4 Then myCell = New TableCell myCell.CssClass = strCssMessage myCell.BorderWidth = New Unit(0) myCell.HorizontalAlign = HorizontalAlign.Right If strCssMessage = "" Then myCell.ForeColor = System.Drawing.Color.Black myCell.BackColor = System.Drawing.Color.LightGray myCell.Font.Name = "Verdana" myCell.Font.Bold = True myCell.Font.Size = New FontUnit(8) End If ButtonYes = New Button ButtonYes.ID = strMessageBoxIDYes ButtonYes.Text = strButtonYes ButtonYes.Width = New Unit(strButtonWidth) ButtonYes.Style.Add("CURSOR", "hand") myCell.Controls.Add(ButtonYes) myRow.Cells.Add(myCell) myCell = New TableCell myCell.Width = New Unit(20) myCell.BorderWidth = New Unit(0) myCell.CssClass = strCssMessage If strCssMessage = "" Then myCell.BackColor = System.Drawing.Color.LightGray End If myRow.Cells.Add(myCell) myCell = New TableCell myCell.CssClass = strCssMessage myCell.BorderWidth = New Unit(0) If strCssMessage = "" Then myCell.ForeColor = System.Drawing.Color.Black myCell.BackColor = System.Drawing.Color.LightGray myCell.Font.Name = "Verdana" myCell.Font.Bold = True myCell.Font.Size = New FontUnit(8) End If If intButton = 2 Then myCell.HorizontalAlign = HorizontalAlign.Left ElseIf intButton = 3 Then myCell.HorizontalAlign = HorizontalAlign.Center End If ButtonNo = New Button ButtonNo.ID = strMessageBoxIDNo ButtonNo.Text = strButtonNo ButtonNo.Width = New Unit(strButtonWidth) ButtonNo.Attributes("WIDTH") = strButtonWidth.ToString() ButtonNo.Attributes("HEIGHT") = strButtonWidth.ToString() ButtonNo.Style.Add("CURSOR", "hand") myCell.Controls.Add(ButtonNo) myRow.Cells.Add(myCell) If intButton = 3 Then myCell = New TableCell myCell.Width = New Unit(10) myCell.BorderWidth = New Unit(0) myCell.CssClass = strCssMessage If strCssMessage = "" Then myCell.BackColor = System.Drawing.Color.LightGray End If myRow.Cells.Add(myCell) myCell = New TableCell myCell.CssClass = strCssMessage myCell.BorderWidth = New Unit(0) myCell.HorizontalAlign = HorizontalAlign.Left If strCssMessage = "" Then myCell.ForeColor = System.Drawing.Color.Black myCell.BackColor = System.Drawing.Color.LightGray myCell.Font.Name = "Verdana" myCell.Font.Bold = True myCell.Font.Size = New FontUnit(8) End If ButtonCancel = New Button ButtonCancel.ID = strMessageBoxIDCancel ButtonCancel.Text = strButtonCancel ButtonCancel.Width = New Unit(strButtonWidth) ButtonCancel.Style.Add("CURSOR", "hand") myCell.Controls.Add(ButtonCancel) myRow.Cells.Add(myCell) End If End If End Sub Protected Overrides Sub AddAttributesToRender(ByVal writer As HtmlTextWriter) ' Rendering message box control to the browser MyBase.AddAttributesToRender(writer) writer.AddAttribute(HtmlTextWriterAttribute.Id, "showimage") ' writer.AddAttribute(HtmlTextWriterAttribute.Style, "Z-INDEX: 9999; LEFT:" + strLeft + "px; WIDTH:" + strLeft + "px; POSITION: absolute; TOP: " + strTop + "px; filter:progid:DXImageTransform.Microsoft.Shadow(color='dimgray', direction="135," strength="3;"") writer.AddAttribute(HtmlTextWriterAttribute.Style, "Z-INDEX: 9999; LEFT:" + strLeft + "px; WIDTH:" + strLeft + "px; POSITION: absolute; TOP: " + strTop + "px; filter:progid:DXImageTransform.Microsoft.Shadow(color=""dimgray"", direction=""135,"" strength=""3"");") End Sub End Class
2. MessageBox.aspx emsmilep.gif

<%@ Page Language="vb" AutoEventWireup="false" Codebehind="MessageBox.aspx.vb" Inherits="WebApplication13.MessageBox1"%> <!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.0 Transitional//EN"> <HTML> <HEAD> <title>MessageBox</title> <meta name="GENERATOR" content="Microsoft Visual Studio.NET 7.0"> <meta name="CODE_LANGUAGE" content="Visual Basic 7.0"> <meta name="vs_defaultClientScript" content="JavaScript"> <meta name="vs_targetSchema" content="http://schemas.microsoft.com/intellisense/ie5"> </HEAD> <body MS_POSITIONING="GridLayout"> <form id="Form1" method="post" runat="server"> <asp:PlaceHolder id="PlaceHolder1" runat="server"></asp:PlaceHolder> <asp:Button id="Button1" style="Z-INDEX: 101; LEFT: 216px; POSITION: absolute; TOP: 8px" runat="server" Text="Click"></asp:Button> </form> </body> </HTML>

3. MessageBox.aspx.vb emsmiled.gif
Public Class MessageBox1 Inherits System.Web.UI.Page Protected WithEvents PlaceHolder1 As System.Web.UI.WebControls.PlaceHolder Protected WithEvents Button1 As System.Web.UI.WebControls.Button Dim newBox As MessageBox = New MessageBox #Region " Web Form Designer Generated Code " 'This call is required by the Web Form Designer. <System.Diagnostics.DebuggerStepThrough()> Private Sub InitializeComponent() End Sub Private Sub Page_Init(ByVal sender As System.Object, ByVal e As System.EventArgs) Handles MyBase.Init 'CODEGEN: This method call is required by the Web Form Designer 'Do not modify it using the code editor. InitializeComponent() End Sub #End Region Private Sub Page_Load(ByVal sender As System.Object, ByVal e As System.EventArgs) Handles MyBase.Load 'Put user code to initialize the page here CheckYesNo() End Sub Private Sub Button1_Click(ByVal sender As System.Object, ByVal e As System.EventArgs) Handles Button1.Click newBox.MessageBoxButton = 3 newBox.MessageBoxTop = 50 newBox.MessageBoxLeft = 150 newBox.MessageBoxWidth = 300 newBox.MessageBoxHeight = 150 newBox.MessageBoxButtonWidth = 50 newBox.MessageBoxIDYes = "yesno" newBox.MessageBoxIDNo = "yesno" newBox.MessageBoxIDCancel = "yesno" newBox.MessageBoxButtonYesText = "Yes" newBox.MessageBoxButtonNoText = "No" newBox.MessageBoxButtonCancelText = "Cancel" newBox.MessageBoxTitle = "Dynamic message box." newBox.MessageBoxMessage = "Do you want to continue?" newBox.MessageBoxImage = "information.gif" PlaceHolder1.Controls.Add(newBox) End Sub Private Sub CheckYesNo() If Request.Form("yesno") = "Yes" Then Response.Write("Button - Yes - Selected") ElseIf Request.Form("yesno") = "No" Then Response.Write("Button - No - Selected") ElseIf Request.Form("yesno") = "Cancel" Then Response.Write("Button - Cancel - Selected") End If End Sub End Class

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值