zoukankan      html  css  js  c++  java
  • HTML5应用:setCustomValidity(message)接口

    本文转自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>
    

      

  • 相关阅读:
    event.preventDefault() 火狐下没有作用。
    输入框禁止键盘输入数字意外的字符
    js遍历数组重复值和数组中对象重复值
    js获取30、X天前得时间
    docker 命令详解
    右键禁止浏览器自带的右键
    Kncokout之绑定事件三
    转:Maven的默认中央仓库以及修改默认仓库&配置第三方jar包从私服下载
    异常: java.security.InvalidKeyException: Illegal key size
    转:Java并发编程:深入剖析ThreadLocal
  • 原文地址:https://www.cnblogs.com/xiaotaoqi/p/5834529.html
Copyright © 2011-2022 走看看