HTML5 表单验证失败的提示语问题


Posted in HTML / CSS onJuly 13, 2017

前言

前端的童鞋在写页面时, 都不可避免的总会踩到 表单验证 这个坑. 这时候, 我们就要跪了, 因为要写一堆 js 来检查. 但是自从 H5 出现后, 很多常见的 表达验证 , 它都已经帮我们实现了, 让我们减轻了很多负担, 就好像下面的:

邮箱地址验证:
 

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Test</title>
</head>
<body>
    <form action="">
        <label >
            邮箱: <input type="email">
        </label>
        <input type="submit">
    </form>
</body>
</html>

HTML5 表单验证失败的提示语问题

邮箱验证是 H5 自身支持的, 但是我们要验证的场景和情况是多种多样的, 那该怎么办? 用回 Js 吗? 很明显没这么蛋疼, 因为 H5 提供了 pattern 属性, 让我们自食其力! 我们可以在 pattern 指定正则表达式, 只要正则写的好, 验证就没烦恼!

正则限定11位数字:

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Test</title>
</head>
<body>
    <form action="">
        <label >
            数字: <input type="text" pattern="^\d{11}$">
        </label>
        <input type="submit">
    </form>
</body>
</html>

HTML5 表单验证失败的提示语问题

问题

大家可以尝试下, 在输入非11位的数字, 都会报错, 这就是 pattern 的功劳. 但是不知道大家发现了一个蛋疼的现象没? 就是如果咱们使用 pattern 的方式去验证表单, 在验证失败时, 它的提示都是 请与所请求的格式保持一致 , 我的天, 我们的用户怎么知道所请求的格式是什么鬼, 总不能让他们去看源码吧, 要真这样, 我们连页面都不用写了, 直接让他们把钱给我们得了, 开个玩笑~

解决方案

有问题, 咱们就得解决, 在面向谷歌编程许久, 终于觅得一良方:

oninvalid:提交的input元素的值为无效值时(这里是正则验证失败),触发

oninvalid事件。oninvalid属于Form 事件。

setCustomValidity():这个是HTML5内置的JS方法,用来自定义提示信息

原来可以通过 oninvalid 和 setCustomValidity 来自定义提示, 那这就好办了, 修改源代码如下:

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Test</title>
</head>
<body>
    <form action="">
        <label >
            数字: <input type="text" pattern="^\d{11}$" oninvalid="setCustomValidity('请输入11位数字')">
        </label>
        <input type="submit">
    </form>
</body>
</html>

结果:

HTML5 表单验证失败的提示语问题

终于不是那个蛋疼的"格式"了, 现在表单验证提示已经很明确的告诉我们, 这里应该输入的是什么样的数据, 这样用户就能更好的修改自己的输入了!

以上所述是小编给大家介绍的HTML5 表单验证失败的提示语问题,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对三水点靠木网站的支持!

HTML / CSS 相关文章推荐
html5+css3之CSS中的布局与Header的实现
Nov 21 HTML / CSS
10分钟入门CSS3 Animation
Dec 25 HTML / CSS
css3给背景图片加颜色遮罩的方法
Nov 05 HTML / CSS
HTML5重塑Web世界它将如何改变互联网
Dec 17 HTML / CSS
html5中valid、invalid、required的定义
Feb 21 HTML / CSS
在HTML5中使用MathML数学公式的简单讲解
Feb 19 HTML / CSS
HTML5触摸事件演化tap事件介绍
Mar 25 HTML / CSS
使用phonegap查找联系人的实现方法
Mar 31 HTML / CSS
完美解决IE8下不兼容rgba()的问题
Mar 31 HTML / CSS
基于HTML5实现类似微信手机摇一摇功能(计算摇动次数)
Jul 24 HTML / CSS
浅析canvas元素的html尺寸和css尺寸对元素视觉的影响
Jul 22 HTML / CSS
HTML5逐步分析实现拖放功能的方法
Sep 30 HTML / CSS
HTML5地理定位_动力节点Java学院整理
Jul 12 #HTML / CSS
HTML5中input[type='date']自定义样式与日历校验功能的实现代码
Jul 11 #HTML / CSS
html5组织内容_动力节点Java学院整理
Jul 10 #HTML / CSS
html5页面结构_动力节点Java学院整理
Jul 10 #HTML / CSS
HTML5单页面手势滑屏切换原理分析
Jul 10 #HTML / CSS
HTML5中图片之间的缝隙完美解决方法
Jul 07 #HTML / CSS
html5是什么_动力节点Java学院整理
Jul 07 #HTML / CSS
You might like
php中adodbzip类实例
2014/12/08 PHP
jqeury eval将字符串转换json的方法
2011/01/20 Javascript
比较新旧两个数组值得增加和删除的JS代码
2013/10/30 Javascript
jQuery实现列表内容的动态载入特效
2015/08/08 Javascript
jQuery实现鼠标经过时出现隐藏层文字链接的方法
2015/10/12 Javascript
js判断手机访问或者PC的几个例子(常用于手机跳转)
2015/12/15 Javascript
javascript实现表单验证
2016/01/29 Javascript
快速掌握Node.js模块封装及使用
2016/03/21 Javascript
js老生常谈之this,constructor ,prototype全面解析
2016/04/05 Javascript
Bootstrap实现带动画过渡的弹出框
2016/08/09 Javascript
CSS3 media queries结合jQuery实现响应式导航
2016/09/30 Javascript
Node.JS中事件轮询(Event Loop)的解析
2017/02/25 Javascript
微信小程序实现流程进度的图样式功能
2018/01/16 Javascript
小程序自定义日历效果
2018/12/29 Javascript
JavaScript对JSON数组简单排序操作示例
2019/01/31 Javascript
原生JavaScript实现滑动拖动验证的示例代码
2019/12/06 Javascript
基于JS实现操作成功之后自动跳转页面
2020/09/25 Javascript
js定时器出现第一次延迟的原因及解决方法
2021/01/04 Javascript
Python中pygame的mouse鼠标事件用法实例
2015/11/11 Python
Python使用poplib模块和smtplib模块收发电子邮件的教程
2016/07/02 Python
Python探索之SocketServer详解
2017/10/28 Python
解决pandas无法在pycharm中使用plot()方法显示图像的问题
2018/05/24 Python
解决使用PyCharm时无法启动控制台的问题
2019/01/19 Python
python实现windows倒计时锁屏功能
2019/07/30 Python
Python图片的横坐标汉字实例
2019/12/04 Python
sklearn和keras的数据切分与交叉验证的实例详解
2020/06/19 Python
H&M旗下高端女装品牌:& Other Stories
2018/05/07 全球购物
印度化妆品购物网站:Nykaa
2018/07/22 全球购物
学生实习自我鉴定
2013/10/11 职场文书
团组织关系介绍信
2014/01/12 职场文书
旷课检讨书1000字
2014/02/14 职场文书
中学生寄语大全
2014/04/03 职场文书
送达通知书
2015/04/25 职场文书
读书笔记怎么写
2015/07/01 职场文书
JS实现扫雷项目总结
2021/05/19 Javascript
React如何使用axios请求数据并把数据渲染到组件
2022/08/05 Javascript