html页面自定义表单验证,自定义HTML5表单验证提示信息

本文探讨了HTML5表单验证在用户体验上的不足,并介绍了如何使用setCustomValidity方法来改善默认提示信息。通过示例展示了如何通过这个方法自定义更友好的错误消息,同时分析了验证逻辑与validationMessage属性的关系,提出了优化后的代码实现。
摘要由CSDN通过智能技术生成

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

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

未调用setCustomValidity()方法

form test

Check

复制代码

执行结果:

A:未输入数据

1.jpeg

B:不匹配

2.jpeg

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

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

form test

Check

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

复制代码

执行结果:

A:为空

3.jpeg

B:不合法

4.jpeg

C:合法

5.jpeg

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

再看看接口属性的变化

调用之前:

A)

6.jpeg

B)

7.jpeg

C)

8.jpeg

调用之后:

A)

9.jpeg

10.jpeg

B)

11.jpeg

12.jpeg

C)

13.jpeg

14.jpeg

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

总结一下:

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

优化后的代码:

form test

Check

function out(i){

var v = i.validity;

if(true === v.valueMessing){

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

}else{

if(true === v.patternMismatch){

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

}else{

i.setCustomValidity("");

}

}

}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值