textField 关于验证(Regex)的一些属性说明
时间:2011-04-27 来源:kevenfox
ExtJS的textField 本身具备验证输入值的一些属性和方法,这些属性和方法都在config参数中进行配置。
1:是否允许空值
allowBlank : Boolean
如果是true,则允许,否则不允许,默认是true。
blankText : String
如果allowBlank 设置为true,并且那个textField的值为空,则会显示blankText属性的字符串以给出错误提示。
2:最长字符和最短字符
maxLength : Number
最长字符(可以达到)
maxLengthText : String
超出设定的最长字符时,会显示maxLengthText属性的字符串以给出错误提示。
minLength : Number
最短字符(可以达到)
minLengthText : String
不足设定的最短字符时,会显示minLengthText属性的字符串以给出错误提示。
3:正则表达式
regex : RegExp
设定正则表达式,eg:/^[abc]$/
regexText : String
输入值违反正则表达式时,会显示regexText属性的字符串以给出错误提示。
可以通过方法isValid( Boolean preventMark ) : Boolean 来得知输入值是否满足所有的限制要求。
注意:
所有的错误提示,分两种,一种是在textField下底框上加上红色波浪线,另一种是显示相应的错误提示字符串,同时给出红色波浪线。
后一种方法需要调用Ext.QuickTips.init();才能生效,默认下,只有前一种方式。
Sample:
1 Ext.onReady(function(){
2 var _win=new Ext.Window({
3 title : "找回密码",
4 width : 180,
5 layout:"form",
6 labelWidth:60,
7 items:[{
8 xtype:"textfield",
9 fieldLabel:"你的姓名" ,
10 allowBlank:false,
11 blankText :'姓名不能为空',
12 minLength :2 ,
13 minLengthText : "姓名最少2个字符",
14 maxLength : 4 ,
15 maxLengthText :"姓名至多4个字符",
16 width : 80,
17 regex : /^[abc]{2,4}$/,
18 regexText : "只能输入abc"
19 }],
20 buttons:[
21 {
22 text:'下一步'
23 },{
24 text:'取消'
25 }
26 ]
27 });
28 Ext.QuickTips.init();
29 _win.show();
30
31 });