如何:使用 Windows 窗体 ErrorProvider 组件显示窗体验证的错误图标
更新:2007 年 11 月
通过使用 Windows 窗体 ErrorProvider 组件,可以在用户输入无效数据时显示错误图标。该窗体上必须至少有两个控件,以便在它们之间切换并由此调用验证代码。
当控件的值无效时显示错误图标
向 Windows 窗体添加两个控件,例如,文本框。
向该窗体添加一个 ErrorProvider 组件。
选择第一个控件,并将代码添加到它的 Validating 事件处理程序。为使此代码正确运行,必须将过程连接到该事件。有关更多信息,请参见 如何:在运行时为 Windows 窗体创建事件处理程序。
下面的代码测试用户输入的数据的有效性;如果该数据无效,将调用 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 e) { errorProvider1.SetError(textBox1, "Not an integer value."); } }
protected void textBox1_Validating(Object sender, CancelEventArgs e) { try { int x = Int32.Parse(textBox1.get_Text()); errorProvider1.SetError(textBox1, ""); } catch(Exception exp) { 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);
运行该项目。向第一个控件中键入无效(在此例中为非数值的)数据,然后切换到第二个控件。当显示错误图标时,用鼠标指针指向它以查看错误文本。
请参见
任务
如何:使用 Windows 窗体 ErrorProvider 组件查看数据集中的错误