更改正在验证的控件的边框或背景颜色
本文关键字:边框 背景 颜色 控件 验证 | 更新日期: 2023-09-27 18:30:14
我正在为使用web表单构建的现有asp.net web应用程序添加验证。我需要验证的输入文本框控件是在服务器端动态创建的。
在创建文本框时,我还可以创建RangeValidator
控件,并将其ControlToValidate
设置为文本框的ID。
验证失败时,RangeValidator
会在放置验证控件的位置显示一条错误消息。
但我宁愿将文本框的border
或background-color
改为红色。如何做到这一点?
您可以在服务器端和客户端向验证器添加自定义逻辑。请查看此链接以获取帮助。http://msdn.microsoft.com/en-us/library/f5db6z8k%28v=vs.90%29.aspx
我不确定你是否需要帮助验证或更改颜色(或两者兼有),但我刚刚尝试了这个双按钮的小应用程序,它似乎很管用。当然,我没有使用任何动态控件名称,并相信"testText"是页面上第一个也是唯一一个"testText"控件。您可能还需要添加一些验证以确保控件存在。
private void button1_Click(object sender, EventArgs e)
{
TextBox tb = new TextBox();
tb.Name = "testText";
this.Controls.Add(tb);
}
private void button2_Click(object sender, EventArgs e)
{
TextBox tb = (TextBox)this.Controls.Find("testText",true)[0];
tb.BackColor = System.Drawing.Color.Red;
}
正如Irfan所说,您可以使用自定义验证器并在服务器上实现验证事件的逻辑。然而,更直接的方法是检查页面是否有效,并检查rangevalidator是否无效。如果您不希望验证器呈现任何消息,请记住将displaymode设置为none。
if(!Page.IsValid && !myRangeValidator.IsValid)
{
// simplified, you will need to search for the control in the whole hierarchy
var ctrlToValidate = Page.FindControl(myRangeValidator.ControlToValidate) as WebControl;
if(ctrlToValidate != null)
{
ctrlToValidate.BorderColor = Color.Red;
}
}
话虽如此,我更喜欢自定义验证器方法。好处是您几乎可以重用上面的所有代码。只需删除第一个if,添加范围验证,设置args。IsValid=false,然后使用其余代码。
循环所有验证器,并将特定的CSS类添加到控件中。我使用母版页,所以需要在内容占位符中找到控件。
const string ErrorCssClass = "error";
Validate();
if (IsPostBack && !IsValid)
{
var content = Form.FindControl("MainContent") as ContentPlaceHolder;
foreach (BaseValidator validator in Validators)
{
if (validator.IsValid)
continue;
var controlToValidate = content.FindControl(validator.ControlToValidate) as WebControl;
if (controlToValidate != null && !controlToValidate.CssClass.Contains(ErrorCssClass))
controlToValidate.CssClass += " " + ErrorCssClass;
}
}