Extjs 表单验证后,几种错误信息展示方式
今天要求对form表单验证,进行系统学习一下,故做了几个示例:
Ext.onReady(function(){
var panel=Ext.create('Ext.form.Panel', {
title:"test the valition"
,width:650
,layout:"anchor"
,renderTo:Ext.getBody()
,defaults:{
margin:"5 0 8 10"
,labelWidth:150
,width:500
}
, defaultType: "textfield"
,items:[
{xtype:"container"
,html:"1.进行远程数据验证,验证不立即执行,而是当鼠标失去焦点才进行验证!"
}
,{
fieldLabel:"remote validation"
,itemId:"show"
, xtype:'textfield'
,labelAlign:"left"
,msgTarget: 'side'
,validateOnChange:false //设置该属性为false,不立即进行验证,而是当鼠标焦点离开进行验证
,plugins:[{ptype:"uxvalidation"}] //自定义远程验证插件,里面调用ajax方式进行后台验证,其实也可以使用validator实现相同的效果。
,remoteValidator: {
params:{
LoginName:"#show" //(通过itemId寻找对应控件)
}
,url:"test.ashx"
}
,listeners:{
errorchange:function(lbl,error){
var me=lbl;
}
}
}
,{ xtype:"container"
,html:"2.进行本地验证(提示类型为under),错误信息将会在下面显示出来"
}
,{
fieldLabel:"local validation (number)"
,itemId:"showTwo"
,xtype:"textfield"
,labelAlign:"left"
,msgTarget:"under"
,minLength:5
,vtype:"number"
}
,{ xtype:"container"
,html:"3.本地和远程验证,只有当本地验证通过,才会调用后台验证"
}
,{
fieldLabel:"local and remote validation" //本地和后台都进行验证,只有当本地验证通过,才会调用后台验证
,itemId:"showThree"
,xtype:"textfield"
,labelAlign:"left"
,msgTarget:"side"
,vtype:"number"
,minLength:5
,plugins:[{ptype:"uxvalidation"}]
,remoteValidator: {
params:{
LoginName:"#showThree" //(通过itemId寻找对应控件)
}
,url:"test.ashx"
}
}
,{ xtype:"container"
,html:"4.不立即进行验证,当鼠标失去焦点才进行验证,错误信息将以title形式提醒"
}
,{
fieldLabel:"Email(title)"
,itemId:"showFour"
,xtype:"textfield"
,labelAlign:"left"
,msgTarget:"title"
,vtype:"email"
,validateOnChange:false //通过设置该属性为false ,不立即进行验证,而是当鼠标离开的时候才进行验证
}
,{ xtype:"container"
,html:"5.直接使用正则进行验证,regex(而不是vtype)验证"
}
,{
fieldLabel:"regex validation (email)"
,itemId:"showFive"
,id:"five"
,xtype:"textfield"
,labelAlign:"left"
,msgTarget:"side"
,regex:/([a-z0-9]*[-_\.]?[a-z0-9]+)*@([a-z0-9]*[-_]?[a-z0-9]+)+[\.][a-z]{2,3}([\.][a-z]{2})?/i //直接正则验证
,regexText:"邮件格式不正确!"
}
,{ xtype:"container"
,html:"6.直接使用函数验证,validator(而不是vtype)验证"
}
,{
fieldLabel:"validator function (number)"
,itemId:"showSix"
,xtype:"textfield"
,labelAlign:"left"
,maskTarget:"none"
,vtype:"number"
,minLength:6
,validator:function(value){ //直接进行函数验证 ,也可以在里面进行远程验证
if(value==3)
return "请不要输入该数字!";
else
return true;
}
}
,{ xtype:"container"
,html:"7.直接显示错误文本信息,通过配置msgTarget为id"
}
,{
xtype:"container"
,layout:"column"
,width:640
,items:[
{
fieldLabel:"the first input"
,itemId:"first"
,xtype:"textfield"
,labelAlign:"left"
,minLength:5
,msgTarget:"showText" //通过配置id属性,改变错误信息显示的位置,直接展示文本信息
,errorMsgCls:"show"
,labelWidth:150
,width:500
,margin:"0 2 2 0"
}
,{
xtype:"container" //等待显示错误文本信息的容器
,id:"showText"
,html:"test test"
,width:130
}
]
}
,{ xtype:"container"
,html:"8.验证和目标控件值是否一致,通过配置target:'itemId'为目标控件"
}
,{
fieldLabel:"the second input"
,itemId:"second"
,xtype:"textfield"
,labelAlign:"left"
,msgTarget:"side"
,target:"first" //通过赋值target属性(其值为要匹配项的itemId)匹配对应的控件,进行相同值比较
,vtype:"twiceInput"
}
]
});
});
Extjs 表单验证后,几种错误信息展示方式的更多相关文章
- extjs表单验证
extjs表单验证 //放在onReady的function(){}中 Ext.QuickTips.init(); //为组件提供提示信息功能,form的主要提示信息就是客户端验证的错误信息. Ext ...
- asp.net 登陆验证 Form表单验证的3种方式 FormsAuthentication.SetAuthCookie;FormsAuthentication.RedirectFromLoginPage;FormsAuthenticationTicket
我们在登陆成功后,使用下面的3种方法,都是同一个目的:创建身份验证票并将其附加到 Cookie, 当我们用Forms认证方式的时候,可以使用HttpContext.Current.User.Ident ...
- NSS_08 extjs表单验证
Extjs做了非常好的表单验证功能, 使用起来非常方便. 系统内置了4种验证功能,分别是alpha, alphanumeric,url, email, 在程序中可以直接使用,(可以结合allowBla ...
- JQuery插件使用之Validation 快速完成表单验证的几种方式
JQuery的Validation插件可以到http://plugins.jquery.com/上去下载.今天来分享一下,关于这个插件的使用. 简易使用 这第一种方式可谓是傻瓜式的使用,我们只需要按照 ...
- ace+validate表单验证(两种方法)
//修改密码(直接在validate中验证提交) $("#changePassword").on(ace.click_event, function() { var html = ...
- bootstrap-table之通用方法( 时间控件,导出,动态下拉框, 表单验证 ,选中与获取信息)
1.bootstrap-table 单击单行选中 $('#gzrwTable').on('click-row.bs.table', function(e, row, $element) { $('.s ...
- jQuery表单验证的几种方法
1.jQuery的框架的验证:validate框架 Jquery Validate 验证规则 (1)required:true 必输字段(2)remote:”check.PHP” 使用ajax方法调用 ...
- Extjs表单验证小结
//放在onReady的function(){}中 Ext.QuickTips.init(); //为组件提供提示信息功能,form的主要提示信息就是客户端验证的错误信息. Ext.form.Fiel ...
- 关于extjs表单布局的几种方式
一.用column布局 layout:'column', defaults:{ style:'float:left;margin:4px;', columnWidth: 0.49, msgTarget ...
随机推荐
- webpack配置备份
package.json: { "name": "webpackTest", "version": "1.0.0", & ...
- javascript冒泡算法
var arr = [10, 10, 3, 2, 5 , 4, 8, 3]; function reSort(arr) { var temp = 0; var len = arr.length; fo ...
- java MAVEN 项目出现红叉
pom.xml <project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w ...
- Gate level Simulation(门级仿真)
1 什么是后仿真? 后仿真也成为时序仿真,门级仿真,在芯片布局布线后将时序文件SDF反标到网标文件上,针对带有时序信息的网标仿真称为后仿真. 2 后仿真是用来干嘛的? 检查电路中的timing vio ...
- nagios二次开发(四)---nagios监控原理和nagios架构简介
nagios监控原理 下面根据上面摘自网络的原理图对nagios的监控原理进行一下简单的说明: 1.nagios通过nsca进行被动监控.那么什么是被动监控呢?被动监测:就是指由被监测的服务器主动上传 ...
- gslX680驱动的移植实践
将gslX680触摸屏驱动移植到自己的开发板上(对应的源码文件gslX680.c),并且实现可以使用make menuconfig进行动态的加载和卸载 因为触摸屏设备属于一种典型的输入设备,所以他的驱 ...
- Python遍历目录下所有文件的最后一行进行判断若错误及时邮件报警-案例
遍历目录下所有文件的最后一行进行判断若错误及时邮件报警-案例: #-*- encoding: utf-8 -*- __author__ = 'liudong' import linecache,sys ...
- DIOCP之DEMO-Echo卡死问题分析
最近很多新朋友在调试echo这个例程时发现,总是卡死客户端或服务器端,这是因为客户端的接收数据用的memo没有处理接受到的行数,导致超过最大行数,而卡死界面,只需要如下操作就可以解决: 引用弦子的:虽 ...
- 查linux端口连接情况用命令netstat
查linux端口连接情况用命令netstat netstat -apn |grep cdnbest 或netstat –apn | grep 3320
- 从西直门立交桥谈IT架构与重构(干货)
2015年8月13日 PM 20:00 Neeke君从一个战场奔赴至另一个战场,回到办公室,打开电脑,登陆微信,精彩的的微社群分享马上就要开始了! 大家好,我是Neeke,中文名高驰涛,PHP开发组成 ...