HTML5表单验证给前端人员带来了便利,但是在用户体验上存在一些缺陷,默认的提示对用户很不友好,无法准确的获取想要的信息。好在大牛们在接口设计的时候提供了setCustomValidilty方法可以自定义提示信息。这是一个好消息,但也存在一些弊端,需要让开人员做额外的一些处理才达到真正想要的目的。
接下来通过以下示例来阐述方法的应用。
未调用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_21 ]quot; placeholder="请输入代码" > <button type="submit">Check</button> </form> </body> </html>
|
复制代码
执行结果:
A:未输入数据
data:image/s3,"s3://crabby-images/e0d32/e0d32ed0be22b07d075745c728a672f2deb632ce" alt="image"
B:不匹配
data:image/s3,"s3://crabby-images/e77c8/e77c8339d797a5110eb626dd5deac9bb2397e6c2" alt="image"
这两个结果都匹配了。但是不匹配这里的提示方案案与预想的不符合。
通过调用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 ]quot; placeholder="请输入代码" > <button type="submit">Check</button> </form> <script type="text/javascript"> document.querySelector("input").setCustomValidity("请输入4位数字的代码"); </script> </body> </html>
|
复制代码
执行结果:
A:为空
data:image/s3,"s3://crabby-images/ce8d5/ce8d57f0eef8fd5cb627366baff19049a20b287c" alt="image"
B:不合法
data:image/s3,"s3://crabby-images/c79f8/c79f85ec78cb3d3a085007306fd9099c738ef528" alt="image"
C:合法
data:image/s3,"s3://crabby-images/d2935/d2935deceb35bd962077094ce44d130e2479f133" alt="image"
从三个操作来看,调用了setCustomValidity方法后,原生的表单验证罗辑都返回false了。悲剧。
再看看接口属性的变化
调用之前:
A)
data:image/s3,"s3://crabby-images/86cb6/86cb624b605e5834254b383323f071209d666b57" alt="image"
B)
data:image/s3,"s3://crabby-images/3fa6e/3fa6e5bcaa5e7f7fdc57b14fdcdf0e10f9e156a5" alt="image"
C)
data:image/s3,"s3://crabby-images/5b7d1/5b7d1915a2bb97e2f986d71855f87348ea7cf6c7" alt="image"
调用之后:
A)
data:image/s3,"s3://crabby-images/7c930/7c9306388af6ba7f14e381c7f34567bba9f42fd8" alt="image"
data:image/s3,"s3://crabby-images/b9d08/b9d08f7446eb2ac35d90a5d28c3cf0684ae1c686" alt="image"
B)
data:image/s3,"s3://crabby-images/03cb5/03cb5836ec0932947509e1b0c4df47a4d03cb6b4" alt="image"
data:image/s3,"s3://crabby-images/48773/487733166d0d074a620b6b54a7d687d6c0a6c954" alt="image"
C)
data:image/s3,"s3://crabby-images/0594e/0594e2dcea2ee1a21c32593d4901a954d0b1209f" alt="image"
data:image/s3,"s3://crabby-images/8d451/8d451352fdb13ca8f1632cfdbca5965ee904bdd2" alt="image"
从上面的截图可以看到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>
|