温馨提示×

温馨提示×

您好,登录后才能下订单哦!

密码登录×
登录注册×
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》

HTML5实战应用:如何让表单验证更友好

发布时间:2020-06-22 00:57:23 来源:网络 阅读:533 作者:Web前端师 栏目:移动开发

HTML5实战应用:如何让表单验证更友好


HTML5表单验证给前端人员带来了便利,但是在用户体验上存在一些缺陷,默认的提示对用户很不友好,无法准确的获取想要的信息。好在大牛们在接口设计的时候提供了setCustomValidilty方法可以自定义提示信息。这是一个好消息,但也存在一些弊端,需要让开人员做额外的一些处理才达到真正想要的目的。


接下来通过以下示例来阐述方法的应用。


未调用setCustomValidity)方法!DOCTYPE html>  


 html


 hea


     ata charset="utf-8  


     titleform test/title>  


 /head  


 body  


     form name="test action="" method="post>  


        input type="text" required pattern="^\d{4[        DISCUZ_CODE_21        ]quot; placeholder="请输入代码" >  


         button type="submit">Check/button>  


     /form>  


 /body>  


 /html> 


复制代码执行结果:


A:未输入数据


B:不匹配


这两个结果都匹配了。但是不匹配这里的提示方案案与预想的不符合。


通过调用setCustomValidity方法来优化提示文案!DOCTYPE html>  


 html>  


 head>  


     mata charset="utf-8">  


     title>form test/title>  


 /head>  


 body>  


     form name="test" action="." method="post">  


         input type="text" required pattern="^\d{4}[        DISCUZ_CODE_22        ]quo; placeholder="请输入代码" >  


         button type="submit">Check/button>  


     /form>  


 script type="text/javascript">  


     document.querySelector"input").setCustomValidity("请输入4位数字的代码");  


 /script>  


 /body>  


/html> 复制代码执行结果:


A:为空


B:不合法


C:合法


从三个操作来看,调用了setCustomValidity方法后,原生的表单验证罗辑都返回false了。悲剧。


再看看接口属性的变化


调用之前:


A)


B)


C)


调用之后:


A)


B)


C)


从上面的截图可以看到validationMessage没清空,valueMissing和patternMismatch都已经验证通了。


总结一下:


从面上可以看出,验证通过与否除了跟validity接口下的属性相关外,还跟validationMessage是否有值有关系。只有当validity接口下的属性(customError除外)都为false并且validationMessage为空时才算验证通过。


优化后的代码:!DOCTYPE html>  


 html>  


 head>  


     mata charset="utf-8">  


     title>form test/title>  


 /head>      


 body>  


     form name="test" action="." method="post">  


         input type="text" required pattern="^\d{4}[        DISCUZ_CODE_23        ]quot; oninput="out(this)" placeholder="请输入代码" >  


         button type="submit">Check/button>  


     /form>  


 script type="text/javascript">  


 function out(i){  


     var v=i.validity;  


     if(true===v.valueMessing){  


         i.setCustomValidity("请填写些字段");  


     }else{  


         if(true===v.patternMismatch){  


             i.setCustomValidity("请输入4位数字的代码");  


         }else{  


             i.setCustomValidity("");  


         }  


     }  


 }  


 /script>  


 /body>  


 /html> 


向AI问一下细节

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

AI