【发布时间】:2013-03-04 07:02:16
【问题描述】:
我正在尝试在我的 .NET 4.5 网络表单应用程序的表单字段中使用新的 required 属性。
但是,由于只有一个<form> 包围了页面上的所有控件(webforms 样式),因此当按下提交按钮时,浏览器不知道要验证哪些字段。
下面附上了具有登录功能和页面搜索功能的页面的剥离版本。
当我点击搜索按钮时,我的浏览器告诉我必须先填写用户名和密码字段。当我尝试登录时,它告诉我必须在搜索字段中输入一些文本。因为所有字段都是同一个<form> 标记的子项。
还有其他人遇到过这个问题或提出了解决方案吗?我想使用 HTML5 属性进行表单验证,没有 javascript 解决方案。
<!DOCTYPE html>
<html>
<head>
<title>Title</title>
</head>
<body>
<form method="post" runat="server" id="mainform">
<%// Search %>
<asp:Panel runat="server" DefaultButton="searchButton" >
<asp:TextBox runat="server" ID="searchQuery" ClientIDMode="Static" required="required" />
<asp:Button runat="server" ID="searchButton" ClientIDMode="Static" Text="Search"/>
</asp:Panel>
<%// Login %>
<asp:Panel runat="server" DefaultButton="signInButton">
<label for="inputusername">Username</label>
<asp:TextBox runat="server" ClientIDMode="Static" ID="inputusername" required="required" />
<label for="inputpassword">Password</label>
<asp:TextBox runat="server" TextMode="Password" ClientIDMode="Static" ID="inputpassword" required="required" />
<asp:Button ID="signInButton" runat="server" />
</asp:Panel>
</form>
</body>
</html>
</html>
【问题讨论】:
-
您是否尝试过将搜索表单输出?
-
对不起,我不明白...
-
您是否尝试过在表单外搜索?
-
不能那样做。表单标签必须包装所有服务器控件...
-
HTML5
required属性不允许任何组进行设置,并且 ASP.NET 不允许(没有 tomfoolery)允许多个form标记(带有服务器控件)。您可以改用RequiredFieldValidator并设置关联控件的ValidationGroup属性。