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

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


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

未调用setCustomValidity()方法
  1. <!DOCTYPE html>  
    javascript

  2. <html>  
    html

  3. <head>  
    前端

  4.      <mata charset="utf-8">  
    java

  5.      <title>form test</title>  
    post

  6. </head>  
    优化

  7. <body>  
    ui

  8.      <form name="test" action="." method="post">  
    this

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

  10.          <button type="submit">Check</button>  
    设计

  11.      </form>  

  12. </body>  

  13. </html> 


复制代码

执行结果:
A:未输入数据



B:不匹配


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

经过调用setCustomValidity方法来优化提示文案
  1. <!DOCTYPE html>  

  2. <html>  

  3. <head>  

  4.      <mata charset="utf-8">  

  5.      <title>form test</title>  

  6. </head>  

  7. <body>  

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

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

  10.          <button type="submit">Check</button>  

  11.      </form>  

  12. <script type="text/javascript">  

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

  14. </script>  

  15. </body>  

  16. </html>

复制代码

执行结果:
A:为空



B:不合法



C:合法


从三个操做来看,调用了setCustomValidity方法后,原生的表单验证罗辑都返回false了。悲剧。
再看看接口属性的变化

调用以前:
A)


B)


C)



调用以后:
A)


B)


C)



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

总结一下:
从面上能够看出,验证经过与否除了跟validity接口下的属性相关外,还跟validationMessage是否有值有关系。只有当validity接口下的属性(customError除外)都为false而且validationMessage为空时才算验证经过。

优化后的代码:
  1. <!DOCTYPE html>  

  2. <html>  

  3. <head>  

  4.      <mata charset="utf-8">  

  5.      <title>form test</title>  

  6. </head>      

  7. <body>  

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

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

  10.          <button type="submit">Check</button>  

  11.      </form>  

  12. <script type="text/javascript">  

  13. function out(i){  

  14.      var v = i.validity;  

  15.      if(true === v.valueMessing){  

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

  17.      }else{  

  18.          if(true === v.patternMismatch){  


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

  20.          }else{  

  21.              i.setCustomValidity("");  

  22.          }  

  23.      }  

  24. }  

  25. </script>  

  26. </body>  

  27. </html> 


复制代码

相关文章
相关标签/搜索