关于ext-js 中的自定义校验

简介:

项目中遇到了前端校验,我们采用的是用vType来创建可以复用的校验器:

需求:校验IPv32

为了创建可以复用的校验器,我们使用了Vtype,定义如下:


  
  
  1. // Custom Vtype for ip address 
  2. Ext.apply(Ext.form.field.VTypes, { 
  3.     ip : function(v) { 
  4.         var reg = /^(25[0-5]|2[0-4][0-9]|[0-1]{1}[0-9]{2}|[1-9]{1}[0-9]{1}|[1-9])\.(25[0-5]|2[0-4][0-9]|[0-1]{1}[0-9]{2}|[1-9]{1}[0-9]{1}|[1-9]|0)\.(25[0-5]|2[0-4][0-9]|[0-1]{1}[0-9]{2}|[1-9]{1}[0-9]{1}|[1-9]|0)\.(25[0-5]|2[0-4][0-9]|[0-1]{1}[0-9]{2}|[1-9]{1}[0-9]{1}|[0-9])$/; 
  5.         return reg.test(v); 
  6.     }, 
  7.     ipText : 'must be numeric, dot -  IP adress format'
  8.     ipMask : /[0-9\.]/i 
  9. }); 

从这段代码可以看出来:

第3行冒号左边的ip表示这个校验器的名字,而右边是一个函数来定义了校验规则, 其中参数v表示被校验的内容。

第4行定义了一个正则表达式,它匹配一个V32的ip地址,我们的校验规则就是让待测的值是否匹配这个正则表达式。

第7行是这个校验出错的提示文本,它会在页面上用红色框子显示出来,对应的样式是x-form-invalid-field.

第8行的正则表达式自动会传递给ext-js的TextField控件,从而在keyPress事件触发时候自动调用从而来限制输入的字符。

 

为了说明这个校验器如何工作的,我们看下应用代码:


  
  
  1. initComponent : function() { 
  2.         this.items = [{ 
  3.             xtype : 'displayfield'
  4.             value : this.sTitle, 
  5.             fieldStyle : 'font-weight:bold;' 
  6.         },  
  7.  
  8. … 
  9.  
  10.           { 
  11.             fieldLabel : 'IP address'
  12.             name : 'nodeIp'
  13.             vtype:'ip'
  14.             maxLength : 60 
  15.         }]; 
  16.         this.callParent(arguments); 
  17.     }, 
  18. }); 

从第13行,可以看出,这里我们对于'IP addres"使用了ip的字段校验器,所以它可以正确的进行字段校验,如果校验结果出错,则会飘红:





本文转自 charles_wang888 51CTO博客,原文链接:http://blog.51cto.com/supercharles888/1191077,如需转载请自行联系原作者
目录
相关文章
|
7月前
|
开发框架 前端开发 JavaScript
在Vue&Element前端项目中,使用FastReport + pdf.js生成并展示自定义报表
在Vue&Element前端项目中,使用FastReport + pdf.js生成并展示自定义报表
|
6月前
|
存储 前端开发 JavaScript
javascript 异常问题之为自定义异常提供丰富的上下文信息如何实现
javascript 异常问题之为自定义异常提供丰富的上下文信息如何实现
|
4月前
|
移动开发 JavaScript 前端开发
原生js如何获取dom元素的自定义属性
原生js如何获取dom元素的自定义属性
121 4
|
5月前
|
JavaScript 前端开发
js_Ipv4以及ipv4段正则校验
几种JavaScript正则表达式,用于校验IPv4地址的有效性,包括支持CIDR表示法的变体。
123 4
|
6月前
|
前端开发 JavaScript 数据安全/隐私保护
前端JS正则校验密码之3种实现方式
这篇文章展示了三种使用JavaScript正则表达式来校验密码的方法,密码需要满足包含大写字母、小写字母、数字及特殊字符,并在8到16位之间,同时提供了示例代码和实现效果。
201 1
前端JS正则校验密码之3种实现方式
|
6月前
|
前端开发 微服务 API
微服务浪潮下的JSF革新:如何在分散式架构中构建统一而强大的Web界面
【8月更文挑战第31天】随着微服务架构的兴起,企业将应用拆分成小型、独立的服务以提高系统可维护性和可扩展性。本文探讨如何在微服务架构下构建和部署JavaServer Faces (JSF) 应用,通过RESTful服务实现前后端分离,提升灵活性和适应性。
76 1
|
6月前
|
前端开发 程序员
HTML+CSS+JavaScript制作动态七夕表白网页(含音乐+自定义文字)
一年一度的520情人节/七夕情人节/女朋友生日/程序员表白,是不是要给女朋友或者正在追求的妹子一点小惊喜呢,今天这篇博客就分享下前端代码如何实现HTML+CSS+JavaScript制作七夕表白网页(含音乐+自定义文字)。赶紧学会了,来制作属于我们程序员的浪漫吧!
203 0
|
7月前
|
JavaScript NoSQL Serverless
函数计算产品使用问题之如何创建一个自定义运行时并指定Node.js版本
阿里云Serverless 应用引擎(SAE)提供了完整的微服务应用生命周期管理能力,包括应用部署、服务治理、开发运维、资源管理等功能,并通过扩展功能支持多环境管理、API Gateway、事件驱动等高级应用场景,帮助企业快速构建、部署、运维和扩展微服务架构,实现Serverless化的应用部署与运维模式。以下是对SAE产品使用合集的概述,包括应用管理、服务治理、开发运维、资源管理等方面。
103 8
|
6月前
|
JavaScript 前端开发 数据安全/隐私保护
Vue.js 表单处理技巧大揭秘!v-model 与自定义验证综合运用,打造高效表单处理体验!
【8月更文挑战第31天】Vue.js 是一款备受欢迎的前端框架,其表单处理功能强大且灵活。v-model 指令可实现双向数据绑定,简化表单元素值与 Vue 实例数据的同步过程;结合自定义验证规则,则能确保用户输入数据符合特定要求。无论是简单的单字段校验还是复杂的多字段验证,Vue.js 均提供了简洁有效的解决方案,有效提升了表单处理效率及用户体验。通过综合运用 v-model 和自定义验证,开发者能够实时反馈错误信息并控制表单状态,从而增强应用的交互性与可靠性。
86 0
|
6月前
|
JavaScript PHP 开发者
PHP中的异常处理与自定义错误处理器构建高效Web应用:Node.js与Express框架实战指南
【8月更文挑战第27天】在PHP编程世界中,异常处理和错误管理是代码健壮性的关键。本文将深入探讨PHP的异常处理机制,并指导你如何创建自定义错误处理器,以便优雅地管理运行时错误。我们将一起学习如何使用try-catch块捕获异常,以及如何通过set_error_handler函数定制错误响应。准备好让你的代码变得更加可靠,同时提供更友好的错误信息给最终用户。

热门文章

最新文章