HTML5應用:讓表單驗證更友好

HTML5%E5%BA%94%E7%94%A8-message%E6%8E%A5%E5%8F%A3.jpg


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:未輸入數據

1336530769_261.jpg



B:不匹配

1336530790_161.jpg


這兩個結果都匹配了。可是不匹配這裏的提示方案案與預想的不符合。

經過調用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:爲空

1336531076_33.jpg



B:不合法

1336531092_68.jpg



C:合法

1336531105_8.jpg


從三個操做來看,調用了setCustomValidity方法後,原生的表單驗證羅輯都返回false了。悲劇。
再看看接口屬性的變化

調用以前:
A)

1336531622_37.jpg


B)

1336531668_55.jpg


C)

1336531785_56.jpg



調用以後:
A)

1336531871_90.jpg


B)

1336531922_37.jpg


C)

1336531977_93.jpg



從上面的截圖能夠看到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> 

相關文章
相關標籤/搜索