如何将RequiredFieldValidator 添加到DropDownList 控件?
Posted
技术标签:
【中文标题】如何将RequiredFieldValidator 添加到DropDownList 控件?【英文标题】:How to add a RequiredFieldValidator to DropDownList control? 【发布时间】:2011-01-17 20:14:19 【问题描述】:我有一个与SqlDataSource
绑定的DropDownList
来显示数据库中的值。
我无法使用RequiredFieldValidator
进行验证。
【问题讨论】:
【参考方案1】:在大多数情况下,您将其视为验证任何其他类型的控件,但使用必填字段验证器的 InitialValue 属性。
<asp:RequiredFieldValidator ID="rfv1" runat="server" ControlToValidate="your-dropdownlist" InitialValue="Please select" ErrorMessage="Please select something" />
基本上它的意思是,如果在下拉列表中选择了除 InitialValue 中设置的 1 以外的任何其他值,则验证将成功。
如果是数据绑定,您需要在之后插入“请选择”值,如下所示
this.ddl1.Items.Insert(0, "Please select");
【讨论】:
嗨伙计,ddl1.Items.Insert(0, new ListItem("Please select", "0"));
那么您确实需要设置InitialValue = "0"
我会以这种方式添加顶部项目,而不是从代码隐藏插入:<asp:DropDownList ID="ddlDepo" runat="server" AppendDataBoundItems="true"> <asp:ListItem Text="Please select" Value="0"></asp:ListItem> </asp:DropDownList>
【参考方案2】:
假设您的下拉列表是:
<asp:DropDownList runat="server" id="ddl">
<asp:ListItem Value="0" text="Select a Value">
....
</asp:DropDownList>
有两种方式:
<asp:RequiredFieldValidator ID="re1" runat="Server" InitialValue="0" />
第二种方法是使用比较验证器:
<asp:CompareValidator ID="re1" runat="Server" ValueToCompare="0" ControlToCompare="ddl" Operator="Equal" />
【讨论】:
如果数据绑定,我认为这仍然比插入列表更可取。您只需更改 DropDownList 即可支持它。<asp:DropDownList runat="server" id="ddl" AppendDataBoundItems="true">
问题:通过使用RequiredFieldValidator,我可以很好地为我的下拉列表获取ErrorMessage,但是,当我从下拉列表中选择时,所有其他表单类,例如我的文本框的错误消息都会清除以及 ddl 的错误消息。【参考方案3】:
如果您使用的是数据源,这里还有另一种无需代码的方式。
注意以下要点:
Value="0"
的 ListItem
在源页面上,未添加到代码中
如果不包含源代码中的ListItem
,将被覆盖
AppendDataBoundItems="true"
在DropDownList
InitialValue="0"
告诉验证器这是
应该触发该验证器(如其他答案中所指出的)
例子:
<asp:DropDownList ID="ddlType" runat="server" DataSourceID="sdsType"
DataValueField="ID" DataTextField="Name" AppendDataBoundItems="true">
<asp:ListItem Value="0" Text="--Please Select--" Selected="True"></asp:ListItem>
</asp:DropDownList>
<asp:RequiredFieldValidator ID="rfvType" runat="server" ControlToValidate="ddlType"
InitialValue="0" ErrorMessage="Type required"></asp:RequiredFieldValidator>
<asp:SqlDataSource ID="sdsType" runat="server"
ConnectionString='<%$ ConnectionStrings:TESTConnectionString %>'
SelectCommand="SELECT ID, Name FROM Type"></asp:SqlDataSource>
【讨论】:
我在搜索为使用 SQL 数据源的下拉列表设置初始值时遇到的最佳答案。【参考方案4】:InitialValue="0" : 在 ddl 中选择第 0 个索引项时将触发初始验证。
<asp:RequiredFieldValidator InitialValue="0" Display="Dynamic" CssClass="error" runat="server" ID="your_id" ValidationGroup="validationgroup" ControlToValidate="your_dropdownlist_id" />
【讨论】:
以上是关于如何将RequiredFieldValidator 添加到DropDownList 控件?的主要内容,如果未能解决你的问题,请参考以下文章
RequiredFieldValidator 不能与 jQuery UI 一起正常工作
RegularExpressionValidator 有效,但 RequiredFieldValidator 无效
ASP:RequiredFieldValidator 和 jQuery 不兼容
RequiredFieldValidator 控件 CompareValidator 控件