禁用 HTML 表单元素的验证

Disable validation of HTML form elements

提问人:nickf 提问时间:6/22/2010 最后编辑:TylerHnickf 更新时间:12/31/2022 访问量:390309

问:

例如,在我的表单中,我想使用新的HTML表单类型(有关类型的更多信息,请参阅此处)。<input type="url" />

问题是 Chrome 希望超级有帮助并为我验证这些元素,除了它很糟糕。如果它未通过内置验证,则除了元素获得焦点外,没有其他消息或指示。我用 预填充了 URL 元素,因此我自己的自定义验证只是将这些值视为空字符串,但 Chrome 拒绝了这一点。如果我能更改它的验证规则,那也会起作用。"http://"

我知道我可以恢复使用,但我希望使用这些新类型的产品(例如:它会自动切换到移动设备上的自定义键盘布局)进行很好的增强:type="text"

有没有办法关闭或自定义自动验证?

验证 表单 HTML 输入

评论

9赞 Mark Amery 12/12/2013
HTML 5.1 草案规范提到了一个 inputmode 属性,如果我理解正确的话,该属性可用于指定当用户与字段交互时应向用户提供的键盘类型,而不暗示任何验证规则。在将来的某个时候,使用属性而不是属性可能是此问题的正确解决方案,但现在还不是。inputmodetype
0赞 Marnen Laibow-Koser 7/4/2014
@MarkAmery 虽然现在获得未来不会太难:$('[inputmode]').each(function () { this.attr({type: this.attr('inputmode'), novalidate: true}) });
1赞 Mark Amery 7/4/2014
@MarnenLaibow-Koser 虽然你所描述的是,如果你只想关闭验证(如提问者所指定的那样),它就可以工作,但它并不能达到与预期相同的结果。按照自己的方式做事,您仍然无法(例如)读取用户键入的非数字值,这些值类型为 。例如,尝试在此小提琴的文本框中键入一些非数字内容,然后单击按钮。inputmodenumber
0赞 Marnen Laibow-Koser 7/7/2014
@MarkAmery 有趣。那是因为根本不接受非数字值吗?<input type='number'>
0赞 Mark Amery 7/7/2014
@MarnenLaibow-Koser:我想是的。关于这个问题的公认答案包括一个指向回答者声称强制执行此行为的规范的链接。

答:

14赞 John Kugelman 6/22/2010 #1

与其尝试对浏览器的验证进行结束运行,不如将 作为占位符文本放入。这是来自您链接的页面:http://

占位符文本

HTML5 给 Web 表单带来的第一个改进是在输入字段中设置占位符文本的能力。只要输入字段为空且未聚焦,占位符文本就会显示在输入字段内。单击(或按 Tab 键)输入字段后,占位符文本就会消失。

您以前可能见过占位符文本。例如,Mozilla Firefox 3.5 现在在位置栏中包含占位符文本,上面写着“搜索书签和历史记录”:

enter image description here

当您点击(或按 Tab 键指向)位置栏时,占位符文本会消失:

enter image description here

具有讽刺意味的是,Firefox 3.5 不支持将占位符文本添加到您自己的 Web 表单中。C'est la vie.

占位符支持

IE  FIREFOX SAFARI  CHROME  OPERA   IPHONE  ANDROID
·   3.7+    4.0+    4.0+    ·       ·       ·

以下是在自己的 Web 表单中包含占位符文本的方法:

<form>
  <input name="q" placeholder="Search Bookmarks and History">
  <input type="submit" value="Search">
</form>

不支持该属性的浏览器将直接忽略它。没有伤害,没有犯规。查看您的浏览器是否支持占位符文本placeholder

它不会完全相同,因为它不会为用户提供“起点”,但至少它已经完成了一半。

评论

5赞 nickf 6/22/2010
+1 的小费,但不幸的是,这对我来说不是一个解决方案。我仍然不想进行任何验证,主要是因为它的用户体验太差了。
36赞 Ben Boyle 6/22/2010 #2

我阅读了规范并在 Chrome 中进行了一些测试,如果您捕获“无效”事件并返回 false,这似乎允许表单提交。

我正在使用jquery,以及这个HTML。

// suppress "invalid" events on URL inputs
$('input[type="url"]').bind('invalid', function() {
  alert('invalid');
  return false;
});

document.forms[0].onsubmit = function () {
  alert('form submitted');
};
<script src="https://ajax.googleapis.com/ajax/libs/jquery/2.1.1/jquery.min.js"></script>
<form>
  <input type="url" value="http://" />
  <button type="submit">Submit</button>
</form>

我还没有在任何其他浏览器中测试过。

评论

2赞 Niels Steenbeek 11/12/2012
FireFox 正在验证输入的更改。然后不会触发“invalid”事件。所以,我没有解决方案。
5赞 Dan Dascalescu 7/7/2015
不起作用。我把代码变成了一个片段。捕获事件并返回 false 不会让表单提交。invalid
855赞 Jakob S 6/22/2010 #3

如果要禁用 HTML 中表单的客户端验证,请将该属性添加到表单元素中。前任:novalidate

<form method="post" action="/foo" novalidate>...</form>

查看 https://www.w3.org/TR/html5/sec-forms.html#element-attrdef-form-novalidate

评论

101赞 bassim 5/30/2012
novalidate="novalidate"并且也是有效的语法。novalidate=""
14赞 user1569050 1/16/2013
@bassim 有效的语法,但过于冗长 - 为什么要输入比您需要的更多内容?
0赞 bassim 1/23/2013
@user1569050 没错,但有时这不是你的决定,你只是想验证它。所以基本上只是为了完整。
11赞 Jelmer 2/11/2013
@user1569050 例如,在像 CakePHP 这样的框架中,当你在 .感谢 bassim 提供额外的信息:)novalidate="novalidate"novalidate => true$optionsFormHelper::create()
3赞 Damien 4/30/2013
这里有一个 chrome 扩展来添加这个属性:chrome.google.com/webstore/detail/html5-form-validation-err/...
27赞 BFTrick #4

我只是想补充一点,在表单中使用 novalidate 属性只会阻止浏览器发送表单。浏览器仍会评估数据并添加 :valid 和 :invalid 伪类。

我发现这一点是因为有效和无效的伪类是我一直在使用的 HTML5 样板样式表的一部分。我刚刚删除了CSS文件中与伪类相关的条目。如果有人找到其他解决方案,请告诉我。

评论

1赞 Muhammad Shahzad 4/24/2017
你是说:<form action="" method="" class="" id="" novalidate> ;)
12赞 Val Entin 8/31/2012 #5

我找到了一个带有 CSS 的 Chrome 解决方案,这个选择器没有绕过本机验证表单,这可能非常有用。

form input::-webkit-validation-bubble-message, 
form select::-webkit-validation-bubble-message,
form textarea::-webkit-validation-bubble-message {
    display:none;
} 

通过这种方式,您还可以自定义您的消息......

我在这个页面上得到了解决方案:http://trac.webkit.org/wiki/Styling%20Form%20Controls

评论

2赞 Blowsie 9/13/2013
这在最新版本的 chrome (29) 中不起作用,我想知道是否因为眨眼
0赞 Tony Brix 7/4/2014 #6

这是我用来防止 chrome 和 opera 显示无效输入对话框的功能,即使在使用 novalidate 时也是如此。

window.submittingForm = false;
$('input[novalidate]').bind('invalid', function(e) {
    if(!window.submittingForm){
        window.submittingForm = true;
        $(e.target.form).submit();
        setTimeout(function(){window.submittingForm = false;}, 100);
    }
    e.preventDefault();
    return false;
});
20赞 plancton 10/10/2014 #7

最好的解决方案是使用文本输入并添加属性 inputmode=“url” 以提供 URL 键盘功能。HTML5 规范就是为了这个目的而考虑的。如果你保留 type=“url”,你会得到语法验证,这并非在所有情况下都有用(最好检查它是否返回 404 错误而不是语法,这是相当宽松的,没有太大帮助)。

例如,您还可以使用属性 pattern=“https?://.+” 覆盖默认模式,以使其更加宽松。

将 novalidate 属性放在表单中并不是所提问题的正确答案,因为它会删除表单中所有字段的验证,例如,您可能希望保留对电子邮件字段的验证。

使用 jQuery 禁用验证也是一个糟糕的解决方案,因为它绝对可以在没有 JavaScript 的情况下工作。

就我而言,我在 URL 输入之前放置了一个带有 2 个选项(http:// 或 https://)的 select 元素,因为我只需要网站(不需要 ftp:// 或其他东西)。这样,我就可以避免输入这个奇怪的前缀(Tim Berners-Lee 最大的遗憾,也许是 URL 语法错误的主要来源),并且我使用带有占位符的 inputmode=“url” 的简单文本输入(没有 HTTP)。我使用jQuery和服务器端脚本来验证网站的真实存在(没有404),并在插入时删除HTTP前缀(我避免使用像pattern=“^(?http)这样的模式。*$“来防止放置前缀,因为我认为最好更宽松)

2赞 blkpingu 10/16/2019 #8

您可以添加一些 JavaScript 来抑制那些令人讨厌的验证气泡并添加您自己的验证器。

document.addEventListener('invalid', (function(){
    return function(e) {
      //prevent the browser from showing default error bubble / hint
      e.preventDefault();
      // optionally fire off some custom validation handler
      // myValidation();
    };
})(), true);
0赞 cweiske 10/29/2019 #9

如果将表单元素标记为 then 无济于事。required=""novalidate=""

规避验证的一种方法是禁用该元素required

评论

1赞 blkpingu 2/3/2021
请举一个简短的例子。你的答案似乎不完整。
0赞 Joaquim d'Souza 7/14/2021
这对我很有用,因为我有隐藏的元素,我想禁用验证。此处的禁用示例:jsfiddle.net/yzm4agdp/1
1赞 TylerH 12/29/2022
如果您不想验证某个字段,为什么要将其标记为必填?只是让它不是必需的。
4赞 Ehsan Paknejad 6/17/2022 #10

在 JSX (JavaScript, React, Angular, Vue &...) 中,您需要在表单中添加(必须使用大写的 camelCase):noValidateV

<form onSubmit={handleSubmit(data)} noValidate>

正如 Jakob S 所说,在纯 HTML 情况下,将 add to form 元素:novalidate

<form method="post" action="/foo" novalidate>...</form>