Validation 禁用HTML5表单元素的验证
在我的表单中,我想使用新的HTML5表单类型,例如Validation 禁用HTML5表单元素的验证,validation,forms,html,input,Validation,Forms,Html,Input,在我的表单中,我想使用新的HTML5表单类型,例如() 问题是,Chrome想要超级有用,并为我验证这些元素,只是它太差劲了。如果未通过内置验证,则除了获取焦点的元素之外,没有其他消息或指示。我用“http://”预先填充URL元素,因此我自己的自定义验证只将这些值视为空字符串,但Chrome拒绝了这一点。如果我能改变它的验证规则,那也行 我知道我可以恢复使用type=“text”,但我希望使用这些新类型提供的功能增强(例如:它会自动切换到移动设备上的自定义键盘布局): 因此,是否有办法关闭或
()
问题是,Chrome想要超级有用,并为我验证这些元素,只是它太差劲了。如果未通过内置验证,则除了获取焦点的元素之外,没有其他消息或指示。我用“http://”
预先填充URL元素,因此我自己的自定义验证只将这些值视为空字符串,但Chrome拒绝了这一点。如果我能改变它的验证规则,那也行
我知道我可以恢复使用type=“text”
,但我希望使用这些新类型提供的功能增强(例如:它会自动切换到移动设备上的自定义键盘布局):
因此,是否有办法关闭或自定义自动验证?您可以将
http://
作为占位符文本放入,而不是尝试在浏览器的验证中进行结束运行。这是您链接的页面上的内容:
占位符文本
HTML5给web表单带来的第一个改进是设置的能力。只要输入字段为空且未聚焦,占位符文本就会显示在输入字段内。只要您单击输入字段(或使用tab键),占位符文本就会消失
您可能以前见过占位符文本。例如,Mozilla Firefox 3.5现在在位置栏中包含占位符文本,内容为“搜索书签和历史记录”:
单击位置栏(或用tab键)时,占位符文本将消失:
具有讽刺意味的是,Firefox3.5不支持将占位符文本添加到您自己的web表单中。这就是生活
占位符支持
以下是如何在自己的web表单中包含占位符文本:
<form>
<input name="q" placeholder="Search Bookmarks and History">
<input type="submit" value="Search">
</form>
不支持占位符
属性的浏览器将直接忽略它。没有伤害,就没有犯规
它不会完全相同,因为它不会为用户提供“起点”,但至少已经达到了一半。我阅读了规范并在Chrome中进行了一些测试,如果捕获到“无效”事件并返回false,则似乎允许表单提交 我正在使用jquery和这个HTML
//抑制URL输入上的“无效”事件
$('input[type=“url”]”)。绑定('invalid',function(){
警报(“无效”);
返回false;
});
document.forms[0]。onsubmit=函数(){
警报(“提交的表格”);
};代码>
提交
如果要在HTML5中禁用表单的客户端验证,请向表单元素添加novalidate属性。例:
<form method="post" action="/foo" novalidate>...</form>
。。。
请参见我只是想补充一点,在表单中使用novalidate属性只会阻止浏览器发送表单。浏览器仍会计算数据并添加:valid和:invalid伪类
我发现这一点是因为有效和无效的伪类是我一直在使用的HTML5样板样式表的一部分。我刚刚删除了CSS文件中与伪类相关的条目。如果有人找到了其他解决方案,请告诉我。我找到了一个使用CSS的Chrome解决方案,这个选择器没有绕过本机验证表单,这可能非常有用
form input::-webkit-validation-bubble-message,
form select::-webkit-validation-bubble-message,
form textarea::-webkit-validation-bubble-message {
display:none;
}
通过这种方式,您还可以自定义您的消息
我在这页上找到了解决方案:
以下是我用来防止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;
});
最好的解决方案是使用文本输入并添加属性inputmode=“url”,以提供url键盘功能。HTML5规范就是为了这个目的而设计的。如果保留type=“url”,则会得到语法验证,但这种验证并不是在所有情况下都有用(最好检查它是否返回404错误,而不是语法,因为语法是非常允许的,并且没有很大帮助)
例如,您还可以使用pattern=“https?:/。+”属性覆盖默认模式,以获得更大的权限
将novalidate属性添加到表单中并不是问题的正确答案,因为它会删除表单中所有字段的验证,例如,您可能希望保留电子邮件字段的验证
使用jQuery禁用验证也是一个糟糕的解决方案,因为它在没有JavaScript的情况下绝对可以工作
在我的例子中,我在URL输入之前放置了一个带有两个选项(http://或https://)的select元素,因为我只需要网站(而不需要ftp://或其他东西)。通过这种方式,我避免键入这种奇怪的前缀(Tim Berners Lee最大的遗憾,可能是URL语法错误的主要来源),我使用带有占位符(不带HTTP)的inputmode=“URL”的简单文本输入。我使用jQuery和服务器端脚本来验证网站(no 404)的真实存在性,并在插入时删除HTTP前缀(我避免使用类似pattern=“^((?HTTP)。)*$”的模式来防止放置前缀,因为我认为最好更为宽松)只需在表单中使用novalidate
<form name="myForm" role="form" novalidate class="form-horizontal" ng-hide="formMain">
干杯 您可以添加一些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);
如果将表单元素标记为required=”“
,则novalidate=“
没有帮助
规避所需验证的的一种方法是.+1作为提示,但不幸的是,这对我来说不是一个解决方案。我仍然不想做任何验证,主要是因为它的用户体验太差了。太好了,我明天会试试,让你知道它是如何运行的。谢谢,哇!我真的很难找到我的提交活动去了哪里。谢谢你,先生!FireFox正在验证输入的更改。则不会触发“无效”事件。所以,对我来说没有解决办法。明天永远不会到来:)行不通
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);