2015-10-11 |

HTML5表单验证实战

HTML5表单验证更友好实战

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

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

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

未调用setCustomValidity()方法

 

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

执行结果:

A:未输入数据

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

B:不匹配

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

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

通过调用setCustomValidity方法来优化提示文案

 

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

执行结果:

A:为空

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

B:不合法

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

C:合法

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

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

再看看接口属性的变化

调用之前:

A)

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

B)

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

C)

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

调用之后:

A)

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

B)

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

C)

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

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

总结一下:

从面上可以看出,验证通过与否除了跟validity接口下的属性相关外,还跟validationMessage是否有值有关系。只有当validity接口下的属性(customError除外)都为false并且validationMessage为空时才算验证通过。

优化后的代码:

 

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

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


这些知识平时工作中积累的一些小技巧,希望抛砖引玉大家一起分享更多前端技巧,更多前端文章请订阅本头条号,会不定期更新,也可以关注微信订阅号“前端观察”。

 

来源:前端观察

 

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

 

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


发表评论

    评价:
    验证码: 点击我更换图片