首页 > Web开发 > 详细

HTML5应用:setCustomValidity(message)接口

时间:2016-09-02 18:47:05      阅读:140      评论:0      收藏:0      [点我收藏+]

本文转自http://tid.tenpay.com/?p=3592

 

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

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

未调用setCustomValidity()方法

 1 <!DOCTYPE html>
 2 <html>
 3 <head>
 4     <mata charset="utf-8">
 5     <title>form test</title>
 6 </head>
 7 
 8 <body>
 9     <form name="test" action="." method="post">
10         <input type="text" required pattern="^\d{4}$" placeholder="请输入代码" >
11         <button type="submit">Check</button>
12     </form>
13 </body>
14 </html>

执行结果:

技术分享

技术分享

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

通过调用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}$" placeholder="请输入代码" >
        <button type="submit">Check</button>
    </form>
<script type="text/javascript">
    document.querySelector("input").setCustomValidity("请输入4位数字的代码");
</script>
</body>
</html>

执行结果:

技术分享

技术分享

技术分享

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

再看看接口属性的变化

调用之前:

A)

技术分享

B)

技术分享

C)

技术分享

调用之后:

 

A)

技术分享

B)

技术分享

C)

技术分享

总结一下:
从面上可以看出,验证通过与否除了跟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}$" 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>

  

 

HTML5应用:setCustomValidity(message)接口

原文:http://www.cnblogs.com/xiaotaoqi/p/5834529.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!