背景:
Ext2标准实现的Radio不够用!一方面是布局不太方便,另一方面是事件比较难用.所以我实现了一种以onChange事件为中心的RadioGroup.
实现代码:
1
Ext.namespace('Ext.ux');
2data:image/s3,"s3://crabby-images/9e1b5/9e1b5b2a3e46b5341b22649797d1794392182f55" alt=""
3
Ext.ux.Radio =function(config)
4data:image/s3,"s3://crabby-images/2a1f3/2a1f35146451967292b66fa62c8f22027e7067cf" alt=""
data:image/s3,"s3://crabby-images/193dc/193dcd26d393debb58fd71fda627adc79a974993" alt=""
{
5
Ext.ux.Radio.superclass.constructor.call(this,config);
6
this.group = config.group;
7
this.value=config.value;
8
};
9data:image/s3,"s3://crabby-images/2a1f3/2a1f35146451967292b66fa62c8f22027e7067cf" alt=""
Ext.extend(Ext.ux.Radio ,Ext.form.Radio,
{
10data:image/s3,"s3://crabby-images/8d7d9/8d7d99ac571b1efcbf1f7e7a4120707c8e90d1fd" alt=""
onRender : function(ct, position)
{
11
Ext.ux.Radio.superclass.onRender.call(this, ct, position);
12data:image/s3,"s3://crabby-images/8d7d9/8d7d99ac571b1efcbf1f7e7a4120707c8e90d1fd" alt=""
if(this.el && this.el.dom)
{
13
this.el.dom.value = this.value;//make the value for radio is the value user has given!
14
}
15
this.on('check',this.onCheck);
16
},
17data:image/s3,"s3://crabby-images/8d7d9/8d7d99ac571b1efcbf1f7e7a4120707c8e90d1fd" alt=""
clearInvalid : function()
{
18
this.group.clearInvalid();
19data:image/s3,"s3://crabby-images/8d7d9/8d7d99ac571b1efcbf1f7e7a4120707c8e90d1fd" alt=""
},markInvalid : function(msg)
{
20
this.group.markInvalid(msg);
21
},
22data:image/s3,"s3://crabby-images/8d7d9/8d7d99ac571b1efcbf1f7e7a4120707c8e90d1fd" alt=""
onClick : function()
{
23
24data:image/s3,"s3://crabby-images/8d7d9/8d7d99ac571b1efcbf1f7e7a4120707c8e90d1fd" alt=""
if(this.el.dom.checked !=this.checked)
{
25
this.group.setValue(this.value);
26
}
27
28
},
29data:image/s3,"s3://crabby-images/8d7d9/8d7d99ac571b1efcbf1f7e7a4120707c8e90d1fd" alt=""
setValue : function(v)
{
30
this.checked = (v === true || v === 'true' || v == '1' || String(v).toLowerCase() == 'on');
31data:image/s3,"s3://crabby-images/8d7d9/8d7d99ac571b1efcbf1f7e7a4120707c8e90d1fd" alt=""
if(this.el && this.el.dom)
{
32
this.el.dom.checked = this.checked;
33
this.el.dom.defaultChecked = this.checked;
34
this.group.el.dom.value=this.value;
35
}
36
},onCheck:function(radio,checked)
37data:image/s3,"s3://crabby-images/8d7d9/8d7d99ac571b1efcbf1f7e7a4120707c8e90d1fd" alt=""
{
38
39
Ext.log('radiao change!');
40
if(checked)
41data:image/s3,"s3://crabby-images/8d7d9/8d7d99ac571b1efcbf1f7e7a4120707c8e90d1fd" alt=""
{
42
var oldValue=this.group.getValue();
43
this.group.onChange(this.group,oldValue,this.getValue());
44
}
45
46
//this.fireEvent('change', this.group, oldValue, newValue);
47
},
48data:image/s3,"s3://crabby-images/8d7d9/8d7d99ac571b1efcbf1f7e7a4120707c8e90d1fd" alt=""
getValue : function()
{
49data:image/s3,"s3://crabby-images/8d7d9/8d7d99ac571b1efcbf1f7e7a4120707c8e90d1fd" alt=""
if(this.rendered)
{
50
return this.el.dom.value;
51
}
52
return false;
53
}
54
});
55data:image/s3,"s3://crabby-images/9e1b5/9e1b5b2a3e46b5341b22649797d1794392182f55" alt=""
56
Ext.ux.RadioGroup=function(config)
57data:image/s3,"s3://crabby-images/2a1f3/2a1f35146451967292b66fa62c8f22027e7067cf" alt=""
data:image/s3,"s3://crabby-images/193dc/193dcd26d393debb58fd71fda627adc79a974993" alt=""
{
58
this.radios=config.radios;
59
this.defaultValue=config.defaultValue||false;
60
Ext.ux.RadioGroup.superclass.constructor.call(this,config);
61
};
62data:image/s3,"s3://crabby-images/2a1f3/2a1f35146451967292b66fa62c8f22027e7067cf" alt=""
Ext.extend(Ext.ux.RadioGroup,Ext.form.Field,
{
63data:image/s3,"s3://crabby-images/8d7d9/8d7d99ac571b1efcbf1f7e7a4120707c8e90d1fd" alt=""
defaultAutoCreate:
{tag:'input', type:'hidden'},
64data:image/s3,"s3://crabby-images/8d7d9/8d7d99ac571b1efcbf1f7e7a4120707c8e90d1fd" alt=""
onRender : function(ct, position)
{
65
66
Ext.ux.RadioGroup.superclass.onRender.call(this, ct, position);
67data:image/s3,"s3://crabby-images/8d7d9/8d7d99ac571b1efcbf1f7e7a4120707c8e90d1fd" alt=""
this.wrap = this.el.wrap(
{cls: "x-form-check-wrap"});
68data:image/s3,"s3://crabby-images/8d7d9/8d7d99ac571b1efcbf1f7e7a4120707c8e90d1fd" alt=""
if (this.radios && this.radios instanceof Array)
{
69
this.els=new Array();
70
this.els[0]=this.el;
71data:image/s3,"s3://crabby-images/8d7d9/8d7d99ac571b1efcbf1f7e7a4120707c8e90d1fd" alt=""
for(var i=0;i<this.radios.length;i++)
{
72
var r=this.radios[i];
73data:image/s3,"s3://crabby-images/8d7d9/8d7d99ac571b1efcbf1f7e7a4120707c8e90d1fd" alt=""
this.els[i]=new Ext.ux.Radio(Ext.apply(
{},
{
74
renderTo:this.wrap,
75
hideLabel:true,
76
group:this
77
},r));
78data:image/s3,"s3://crabby-images/8d7d9/8d7d99ac571b1efcbf1f7e7a4120707c8e90d1fd" alt=""
if (this.horizontal)
{
79data:image/s3,"s3://crabby-images/8d7d9/8d7d99ac571b1efcbf1f7e7a4120707c8e90d1fd" alt=""
this.els[i].el.up('div.x-form-check-wrap').applyStyles(
{
80
'display': 'inline',
81
'padding-left': '5px'
82
});
83
}
84
}
85
if(this.hidden)this.hide();
86
}
87
this.setDefaultValue();
88data:image/s3,"s3://crabby-images/8d7d9/8d7d99ac571b1efcbf1f7e7a4120707c8e90d1fd" alt=""
},initValue : function()
{
89
//Ext.log('initValue for'+this.name);
90data:image/s3,"s3://crabby-images/8d7d9/8d7d99ac571b1efcbf1f7e7a4120707c8e90d1fd" alt=""
if(this.value !== undefined)
{
91
this.el.dom.value=this.value;
92
93data:image/s3,"s3://crabby-images/8d7d9/8d7d99ac571b1efcbf1f7e7a4120707c8e90d1fd" alt=""
}else if(this.el.dom.value.length > 0)
{
94
this.value=this.el.dom.value;
95
}
96
},getValue:function()
97data:image/s3,"s3://crabby-images/8d7d9/8d7d99ac571b1efcbf1f7e7a4120707c8e90d1fd" alt=""
{
98data:image/s3,"s3://crabby-images/8d7d9/8d7d99ac571b1efcbf1f7e7a4120707c8e90d1fd" alt=""
if(this.rendered)
{
99
return this.el.dom.value;
100
}
101
return false;
102data:image/s3,"s3://crabby-images/8d7d9/8d7d99ac571b1efcbf1f7e7a4120707c8e90d1fd" alt=""
/**//*
103
if(this.value !== undefined){
104
return this.value;
105
}else if(this.el.dom.value.length > 0){
106
return this.el.dom.value;
107
}
108
*/
109
},setValue:function(v)
110data:image/s3,"s3://crabby-images/8d7d9/8d7d99ac571b1efcbf1f7e7a4120707c8e90d1fd" alt=""
{
111
var oldValue=this.getValue();
112
if(oldValue==v)return ;
113
for(var j=0;j<this.els.length;j++)
114data:image/s3,"s3://crabby-images/8d7d9/8d7d99ac571b1efcbf1f7e7a4120707c8e90d1fd" alt=""
{
115
if(this.els[j].value==v)
116data:image/s3,"s3://crabby-images/8d7d9/8d7d99ac571b1efcbf1f7e7a4120707c8e90d1fd" alt=""
{
117
this.els[j].setValue(true);
118
}
119
else
120data:image/s3,"s3://crabby-images/8d7d9/8d7d99ac571b1efcbf1f7e7a4120707c8e90d1fd" alt=""
{
121
this.els[j].setValue(false);
122
}
123
}
124
this.el.dom.value=v;
125
this.fireEvent('change', this.group, oldValue, v);
126
},
127
setDefaultValue:function()
128data:image/s3,"s3://crabby-images/8d7d9/8d7d99ac571b1efcbf1f7e7a4120707c8e90d1fd" alt=""
{
129
for(var j=0;j<this.els.length;j++)
130data:image/s3,"s3://crabby-images/8d7d9/8d7d99ac571b1efcbf1f7e7a4120707c8e90d1fd" alt=""
{
131
if(this.els[j].value==this.defaultValue)
132data:image/s3,"s3://crabby-images/8d7d9/8d7d99ac571b1efcbf1f7e7a4120707c8e90d1fd" alt=""
{
133
this.els[j].setValue(true);
134
return;
135
}
136
else
137data:image/s3,"s3://crabby-images/8d7d9/8d7d99ac571b1efcbf1f7e7a4120707c8e90d1fd" alt=""
{
138
if(j<this.els.length-1)
139data:image/s3,"s3://crabby-images/8d7d9/8d7d99ac571b1efcbf1f7e7a4120707c8e90d1fd" alt=""
{
140
this.els[j].setValue(false);
141
}
142
else
143data:image/s3,"s3://crabby-images/8d7d9/8d7d99ac571b1efcbf1f7e7a4120707c8e90d1fd" alt=""
{
144
this.els[j].setValue(true);
145
}
146
147
}
148
}
149
},
150
// private
151data:image/s3,"s3://crabby-images/8d7d9/8d7d99ac571b1efcbf1f7e7a4120707c8e90d1fd" alt=""
onDestroy : function()
{
152data:image/s3,"s3://crabby-images/8d7d9/8d7d99ac571b1efcbf1f7e7a4120707c8e90d1fd" alt=""
if (this.radios && this.radios instanceof Array)
{
153
var cnt = this.radios.length;
154data:image/s3,"s3://crabby-images/8d7d9/8d7d99ac571b1efcbf1f7e7a4120707c8e90d1fd" alt=""
for(var x=1;x<cnt;x++)
{
155
this.els[x].destroy();
156
}
157
}
158data:image/s3,"s3://crabby-images/8d7d9/8d7d99ac571b1efcbf1f7e7a4120707c8e90d1fd" alt=""
if(this.wrap)
{
159
this.wrap.remove();
160
}
161
Ext.ux.RadioGroup.superclass.onDestroy.call(this);
162
},
163
164
// private
165
166data:image/s3,"s3://crabby-images/8d7d9/8d7d99ac571b1efcbf1f7e7a4120707c8e90d1fd" alt=""
onChange : function(oldValue, newValue)
{
167
this.fireEvent('change', this, oldValue, newValue);
168
}
169data:image/s3,"s3://crabby-images/96c01/96c01a9005d00151a1af2189b6a9f266915ba654" alt=""
170
});
171
Ext.reg('ux-radiogroup', Ext.ux.RadioGroup);
例子:
data:image/s3,"s3://crabby-images/2a1f3/2a1f35146451967292b66fa62c8f22027e7067cf" alt=""
var boolField= new Ext.ux.RadioGroup(
{
fieldLabel : "actionNow",
allowBlank : true,
horizontal:true,
maxLength : 200,
defaultValue:'true',
name : "activity.ishavecare",
data:image/s3,"s3://crabby-images/8d7d9/8d7d99ac571b1efcbf1f7e7a4120707c8e90d1fd" alt=""
radios:[
{boxLabel:'Yes',value:'true'},
{boxLabel:'No',value:'false'}]
});
boolField.on('change',function(radioGroup,oldValue,newValue)
data:image/s3,"s3://crabby-images/2a1f3/2a1f35146451967292b66fa62c8f22027e7067cf" alt=""
data:image/s3,"s3://crabby-images/193dc/193dcd26d393debb58fd71fda627adc79a974993" alt=""
{
data:image/s3,"s3://crabby-images/96c01/96c01a9005d00151a1af2189b6a9f266915ba654" alt=""
Ext.log('value changes from '+oldValue+" to "+newValue);
}
)
Let life be beautiful like summer flowers and death like autumn leaves.