Практическое руководство. Ответ на события серверного веб-элемента управления "Кнопка"

Visual Studio 2010

Обновлен: Ноябрь 2007

При нажатии серверного веб-элемента Button, LinkButton или ImageButton текущая страница отправляется не сервер, где она обрабатывается.

Ответ на событие кнопки

  • Создайте обработчик событий для одного из следующих событий:

    • Событие Page_Load страницы. Поскольку кнопка всегда инициирует передачу страницы на сервер, этот метод выполняется всегда. Используйте событие Page_Load, когда не имеет значения, какая именно кнопка нажата, а требуется только отправить форму.

    • Событие Click кнопки. Напишите обработчик событий для этого события, когда важно знать, какая кнопка была нажата.

      h84w616y.alert_note(ru-ru,VS.100).gifПримечание.

      Если используется элемент управления ImageButton и требуется узнать координаты x и y щелчка, необходимо создать обработчик этого события. Подробные сведения см. в разделе Практическое руководство. Координаты в серверном веб-элементе управления ImageButton.

    В следующем примере показано, каким может быть ответ, когда пользователь нажимает серверный элемент управления Button. Метод отображает сообщение в серверном веб-элементе управления Label.

    Private Sub Button1_Click(ByVal sender As System.Object, ByVal e As System.EventArgs) Handles Button1.Click
       Label1.Text="You clicked a button"
    End Sub
    

    public void Button1_Click (object sender, System.EventArgs e)
    {
       Label1.Text="You clicked a button.";
    }
    

    В следующем примере показан ответ на нажатие кнопки в обработчике событий Page_Load. Данный метод проверяет свойство IsPostBack страницы и определяет, обрабатывается ли эта страница впервые или она была отправлена в результате нажатия кнопки.

    Private Sub Page_Load(ByVal Sender As System.Object, ByVal e _
        As System.EventArgs) Handles MyBase.Load
        If Not IsPostback Then
            ' This is called the first time the page has loaded.
            ' The user will not have been able to click any buttons yet.
        Else
            ' This is called if the form has been posted back, possibly
            ' by a button click.
            Me.Label1.Text = "You clicked a button."
        End If
    End Sub
    

    private void Page_Load(object sender, System.EventArgs e)
    {
       if (!IsPostBack)
       {
          // Evals true first time browser hits the page.
       }
       else
       {
          // This is called if the form has been posted back, possibly
          // by a button click.
          this.Label1.Text = "You clicked a button.";
       }
    }
    

    В следующем примере показан простой калькулятор, выполняющий четыре действия с целыми числами. Выполнив привязку всех кнопок (Add, Subtract, Multiply и Divide) к одному и тому же методу, можно обработать все вычисления в одном месте и избежать повторов в коде. Для привязки кнопок к методу Calculate в Visual Basic используется метод AddHandler, а в C# — оператор +=. Чтобы убедиться, что входные значения являются целыми числами, можно добавить код обработки ошибок к методу Calculate или использовать проверку элементов управления, доступных в веб-формах.

    ' Set the CommandName property of the buttons to "Add", 
    ' "Subtract", "Multiply", and "Divide".
    Private Sub Page_Load(ByVal sender As System.Object, ByVal e As System.EventArgs) Handles MyBase.Load
       AddHandler Me.btnAdd.Click, AddressOf Calculate
       AddHandler Me.btnSubtract.Click, AddressOf Calculate
       AddHandler Me.btnMultiply.Click, AddressOf Calculate
       AddHandler Me.btnDivide.Click, AddressOf Calculate
    End Sub
    
    Public Sub Calculate(ByVal sender As Object, ByVal e As System.EventArgs)
       Dim op1 As Integer = CType(Me.TextBox1.Text, Integer)
       Dim op2 As Integer = CType(Me.TextBox2.Text, Integer)
       Dim result As Integer
       Select Case CType(sender, Button).CommandName
          Case "Add"
             result = op1 + op2
          Case "Subtract"
             result = op1 - op2
          Case "Multiply"
             result = op1 * op2
          Case "Divide"
             ' Divide two numbers and return an integer result.
             If op2 > 0 Then
                   result = op1 \ op2
             Else
                   result = 0
             End If
          Case Else
             ' Error handling code here.
       End Select
       Label1.Text = result.ToString()     
    End Sub
    

    // Set the CommandName property of the buttons to "Add", _
    // "Subtract", "Multiply", and "Divide".
    protected void Page_Load(object sender, EventArgs e)
    {
       btnAdd.Click += new System.EventHandler(this.Calculate);
       btnSubtract.Click += new System.EventHandler(this.Calculate);
       btnMultiply.Click += new System.EventHandler(this.Calculate);
       btnDivide.Click += new System.EventHandler(this.Calculate);
    }
    
    protected void Calculate (object sender, System.EventArgs e)
    {
       int op1 = Convert.ToInt16(TextBox1.Text);
       int op2 = Convert.ToInt16(TextBox2.Text);
       int result = 0;
       switch(((Button)sender).CommandName)
       {
          case "Add" :
             result = op1 + op2;
             break;
          case "Subtract" :
             result = op1 - op2;
             break;
          case "Multiply" :
             result = op1 * op2;
             break;
          case "Divide" :
             // Integer division.
             if (op2 > 0) 
                   result = op1 / op2;
             else
                   result = 0;
             break;
          default:
             // Error handling code here.
             break;
       }
       Label1.Text = result.ToString();
    }
    
Показ: