快上网专注成都网站设计 成都网站制作 成都网站建设
成都网站建设公司服务热线:028-86922220

网站建设知识

十年网站开发经验 + 多家企业客户 + 靠谱的建站团队

量身定制 + 运营维护+专业推广+无忧售后,网站问题一站解决

HTML5实战应用:如何让表单验证更友好-创新互联

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

创新互联建站-专业网站定制、快速模板网站建设、高性价比临邑网站开发、企业建站全套包干低至880元,成熟完善的模板库,直接使用。一站式临邑网站制作公司更省心,省钱,快速模板网站建设找我们,业务覆盖临邑地区。费用合理售后完善,十年实体公司更值得信赖。

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

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

未调用setCustomValidity)方法!DOCTYPE html>

 html

 hea

   ata charset="utf-8

   titleform 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:未输入数据

B:不匹配

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

通过调用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     ]quo; placeholder="请输入代码" >

     button type="submit">Check/button>

   /form>

 script type="text/javascript">

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

 /script>

 /body>

/html> 复制代码执行结果:

A:为空

B:不合法

C:合法

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

再看看接口属性的变化

调用之前:

A)

B)

C)

调用之后:

A)

B)

C)

从上面的截图可以看到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>

另外有需要云服务器可以了解下创新互联cdcxhl.cn,海内外云服务器15元起步,三天无理由+7*72小时售后在线,公司持有idc许可证,提供“云服务器、裸金属服务器、高防服务器、香港服务器、美国服务器、虚拟主机、免备案服务器”等云主机租用服务以及企业上云的综合解决方案,具有“安全稳定、简单易用、服务可用性高、性价比高”等特点与优势,专为企业上云打造定制,能够满足用户丰富、多元化的应用场景需求。


分享题目:HTML5实战应用:如何让表单验证更友好-创新互联
标题路径:http://6mz.cn/article/pedhs.html

其他资讯