Практическое руководство. Отображение значков ошибок при проверке введенных в форму данных с помощью компонента ErrorProvider в Windows Forms
Компонент Windows Forms ErrorProvider можно использовать для отображения значка ошибки, когда пользователь вводит недопустимые данные. Для перехода между ними и вызова кода проверки необходимо иметь по крайней мере два элемента управления.
Отображение значка ошибки при недопустимом значении элемента управления
Добавьте два элемента управления (например, текстовые поля) в форму Windows Forms.
Добавьте в форму компонент ErrorProvider.
Выберите первый элемент управления и добавьте код в обработчик событий Validating. Чтобы этот код выполнялся правильно, процедура должна быть подключена к событию. Дополнительные сведения см. в разделе Практическое руководство. Создание обработчиков событий для Windows Forms во время выполнения.
В следующем коде проверяется допустимость введенных пользователем данных; если данные недопустимы, вызывается метод SetError. Первый аргумент метода SetError указывает элемент управления, рядом с которым будет отображаться значок. Второй аргумент — это отображаемый текст ошибки.
Private Sub TextBox1_Validating(ByVal Sender As Object, _ ByVal e As System.ComponentModel.CancelEventArgs) Handles _ TextBox1.Validating If Not IsNumeric(TextBox1.Text) Then ErrorProvider1.SetError(TextBox1, "Not a numeric value.") Else ' Clear the error. ErrorProvider1.SetError(TextBox1, "") End If End Sub
protected void textBox1_Validating (object sender, System.ComponentModel.CancelEventArgs e) { try { int x = Int32.Parse(textBox1.Text); errorProvider1.SetError(textBox1, ""); } catch (Exception ex) { errorProvider1.SetError(textBox1, "Not an integer value."); } }
private: System::Void textBox1_Validating(System::Object ^ sender, System::ComponentModel::CancelEventArgs ^ e) { try { int x = Int32::Parse(textBox1->Text); errorProvider1->SetError(textBox1, ""); } catch (System::Exception ^ ex) { errorProvider1->SetError(textBox1, "Not an integer value."); } }
(Visual C#, Visual C++) Поместите следующий код в конструктор формы для регистрации обработчика событий.
this.textBox1.Validating += new System.ComponentModel.CancelEventHandler(this.textBox1_Validating);
this->textBox1->Validating += gcnew System::ComponentModel::CancelEventHandler (this, &Form1::textBox1_Validating);
Запустите проект. Введите недопустимые (в этом примере нечисловые) данные в первый элемент управления, а затем перейдите ко второму элементу управления. Когда отображается значок ошибки, наведите на него указатель мыши, чтобы увидеть текст ошибки.
См. также
.NET Desktop feedback