- 浏览: 1298830 次
- 性别:
- 来自: 北京
文章分类
- 全部博客 (471)
- Database (29)
- Java (47)
- Frameworks (9)
- JavaScript (30)
- Others (27)
- ExtJS (26)
- Linux (49)
- Windows (11)
- Web (8)
- Ubunt (9)
- Shell (21)
- MySQL (26)
- Redis (9)
- Git (6)
- Maven (29)
- Python (3)
- Nginx (10)
- Nodejs (7)
- Network (1)
- GO (2)
- Docker (36)
- MongoDB (5)
- Intellij idea (7)
- Ruby (3)
- Weblogic (3)
- CSS (15)
- VMware (3)
- Tomcat (6)
- Cache (2)
- PHP (8)
- Mac (7)
- jQuery (3)
- Spring (8)
- HTML5 (2)
- Kubernetes (8)
最新评论
-
masuweng:
Intellij idea 主题下载网址 -
mimicom:
还有一个情况, 也是连不上 2018-05-06T06:01: ...
docker-compose 部署shipyard -
lixuansong:
put()方法调用前必须先手动调用remove(),不然不会实 ...
JavaScript创建Map对象(转) -
jiao_zg22:
方便问下,去哪里下载包含Ext.ux.TabCloseMenu ...
Ext.ux.TabCloseMenu插件的使用(TabPanel右键关闭菜单) 示例 -
netwelfare:
对于基本类型的讲解,文章写的有点简单了,没有系统化,这篇文章介 ...
Java 基础类型范围
Ext.ux.RadioGroup的使用(让各radio使用不同的名称) 示例
我们在使用Ext.form.RadioGroup的时候需要将各radio组件的name设置成同一个,这样用户在点选时才能保证一次只有一个radio被选中,但在项目开发中往往需要去取某一个指定的radio做一些操作,如果使用Ext.form.RadioGroup给开发带来了很多的不方便。为避免该类问题,我们在创建RadioGroup组件的时候我们往往使用Ext官方论坛中的Ext.ux.RadioGroup扩展组件来代替。
创建调用的HTML:
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=GBK" />
<title></title>
<link rel="stylesheet" type="text/css" href="extjs/resources/css/ext-all.css" />
<script type="text/javascript" src="extjs/adapter/ext/ext-base.js"></script>
<script type="text/javascript" src="extjs/ext-all.js"></script>
<script type="text/javascript" src="./Ext.ux.RadioGroup.js"></script>
<style type="text/css">
</style>
<script>
Ext.onReady(function() {
new Ext.Panel({
renderTo : document.body,
layout : 'form',
items : [{
xtype : 'ux-radiogroup',
fieldLabel : 'ux-radiogroup',
name : 'radiobox_a',
horizontal : true,
radios : [{
value : 1,
boxLabel : 'box 1',
name:'b1',
id:'b1',
listeners : {
'check' : function(r, c) {
alert(r.boxLabel + ": " + (c ? "checked" : "unchecked"));
}
}
}, {
value : 2,
name:'b2',
id:'b2',
boxLabel : 'box 2',
checked : true
}, {
value : 3,
name:'b3',
id:'b2',
boxLabel : 'box 3'
}]
},new Ext.form.RadioGroup({
width : 220,
// hideLabel:true,
fieldLabel : 'radiogroup',
style:'margin-left:100px;',
columns : 1,
vertical :true,
items:[
{boxLabel:'box 1',inputValue:'value1',name:'RadioGroup'},
{boxLabel:'box 2',inputValue:'value2',name:'RadioGroup'},
{boxLabel:'box 3',inputValue:'value3',name:'RadioGroup',
listeners:{
check:function(el,checked){
alert(checked);
}
}
}]
})]
});
});
</script>
</head>
<body>
</body>
</html>
Ext.ux.RadioGroup.js文件源码:
/**
* @author Robert Williams (vtswingkid)
* @version 1.0.4
*/
Ext.namespace('Ext.ux');
Ext.ux.RadioGroup = Ext.extend(Ext.form.Field, {
/**
* @cfg {String} focusClass The CSS class to use when the checkbox receives focus (defaults to undefined)
*/
focusClass : undefined,
/**
* @cfg {String} fieldClass The default CSS class for the checkbox (defaults to "x-form-field")
*/
fieldClass: "x-form-field",
/**
* @cfg {Boolean} checked True if the the checkbox should render already checked (defaults to false)
*/
checked: false,
/**
* @cfg {String/Object} autoCreate A DomHelper element spec, or true for a default element spec (defaults to
* {tag: "input", type: "radio", autocomplete: "off"})
*/
defaultAutoCreate : { tag: "input", type: 'radio', autocomplete: "off"},
/**
* @cfg {String} boxLabel The text that appears beside the checkbox
*/
getId:function(){
//if multiple radios are defined use this information
if(this.radios && this.radios instanceof Array){
if(this.radios.length){
var r=this.radios[0];
this.value=r.value;
this.boxLabel=r.boxLabel;
this.checked=r.checked || false;
this.readOnly=r.readOnly || false;
this.disabled=r.disabled || false;
this.tabIndex=r.tabIndex;
this.cls=r.cls;
this.listeners=r.listeners;
this.style=r.style;
this.bodyStyle=r.bodyStyle;
this.hideParent=r.hideParent;
this.hidden=r.hidden;
}
}
Ext.ux.RadioGroup.superclass.getId.call(this);
},
// private
initComponent : function(){
Ext.ux.RadioGroup.superclass.initComponent.call(this);
this.addEvents(
/**
* @event change
* Fires when the radio value changes.
* @param {Ext.vx.RadioGroup} this This radio
* @param {Boolean} checked The new checked value
*/
'check'
);
},
// private
onResize : function(){
Ext.ux.RadioGroup.superclass.onResize.apply(this, arguments);
if(!this.boxLabel){
this.el.alignTo(this.wrap, 'c-c');
}
},
// private
initEvents : function(){
Ext.ux.RadioGroup.superclass.initEvents.call(this);
this.el.on("click", this.onClick, this);
this.el.on("change", this.onClick, this);
},
// private
getResizeEl : function(){
return this.wrap;
},
// private
getPositionEl : function(){
return this.wrap;
},
/**
* Overridden and disabled. The editor element does not support standard valid/invalid marking. @hide
* @method
*/
markInvalid : Ext.emptyFn,
/**
* Overridden and disabled. The editor element does not support standard valid/invalid marking. @hide
* @method
*/
clearInvalid : Ext.emptyFn,
// private
onRender : function(ct, position){
Ext.ux.RadioGroup.superclass.onRender.call(this, ct, position);
this.wrap = this.el.wrap({cls: "x-form-check-wrap"});
if(this.boxLabel){
this.wrap.createChild({tag: 'label', htmlFor: this.el.id, cls: 'x-form-cb-label', html: this.boxLabel});
}
if(!this.isInGroup){
this.wrap.applyStyles({'padding-top':'2px'});
}
if(this.checked){
this.setChecked(true);
}else{
this.checked = this.el.dom.checked;
}
if (this.radios && this.radios instanceof Array) {
this.els=new Array();
this.els[0]=this.el;
for(var i=1;i<this.radios.length;i++){
var r=this.radios[i];
this.els[i]=new Ext.ux.RadioGroup({
renderTo:this.wrap,
hideLabel:true,
boxLabel:r.boxLabel,
checked:r.checked || false,
value:r.value,
name:this.name || this.id,
readOnly:r.readOnly || false,
disabled:r.disabled || false,
tabIndex:r.tabIndex,
cls:r.cls,
listeners:r.listeners,
style:r.style,
bodyStyle:r.bodyStyle,
hideParent:r.hideParent,
hidden:r.hidden,
isInGroup:true
});
if (this.horizontal) {
this.els[i].el.up('div.x-form-check-wrap').applyStyles({
'display': 'inline',
'padding-left': '5px'
});
}
}
if(this.hidden)this.hide();
}
},
initValue : function(){
if(this.value !== undefined){
this.el.dom.value=this.value;
}else if(this.el.dom.value.length > 0){
this.value=this.el.dom.value;
}
},
// private
onDestroy : function(){
if (this.radios && this.radios instanceof Array) {
var cnt = this.radios.length;
for(var x=1;x<cnt;x++){
this.els[x].destroy();
}
}
if(this.wrap){
this.wrap.remove();
}
Ext.ux.RadioGroup.superclass.onDestroy.call(this);
},
setChecked:function(v){
if(this.el && this.el.dom){
var fire = false;
if(v != this.checked)fire=true;
this.checked=v;
this.el.dom.checked = this.checked;
this.el.dom.defaultChecked = this.checked;
if(fire)this.fireEvent("check", this, this.checked);
}
},
/**
* Returns the value of the checked radio.
* @return {Mixed} value
*/
getValue : function(){
if(!this.rendered) {
return this.value;
}
var p=this.el.up('form');//restrict to the form if it is in a form
if(!p)p=Ext.getBody();
var c=p.child('input[name='+escape(this.el.dom.name)+']:checked', true);
return (c)?c.value:this.value;
},
// private
onClick : function(){
if(this.el.dom.checked != this.checked){
var p = this.el.up('form');
if (!p)
p = Ext.getBody();
var els = p.select('input[name=' + escape(this.el.dom.name) + ']');
els.each(function(el){
if (el.dom.id == this.id) {
this.setChecked(true);
}
else {
var e = Ext.getCmp(el.dom.id);
e.setChecked.apply(e, [false]);
}
}, this);
}
},
/**
* Checks the radio box with the matching value
* @param {Mixed} v
*/
setValue : function(v){
if(!this.rendered) {
this.value=v;
return;
}
var p=this.el.up('form');//restrict to the form if it is in a form
if(!p)p=Ext.getBody();
var target = p.child('input[name=' + escape(this.el.dom.name) + '][value=' + v + ']', true);
if (target) target.checked = true;
},
clear: function(){
if (!this.rendered) return;
var p = this.el.up('form');//restrict to the form if it is in a form
if (!p) p = Ext.getBody();
var c = p.child('input[name=' + escape(this.el.dom.name) + ']:checked', true);
if (c) c.checked = false;
},
disable: function(){
if (!this.rendered) return;
var p = this.el.up('form');//restrict to the form if it is in a form
if (!p) p = Ext.getBody();
var els = p.select('input[name=' + escape(this.el.dom.name) + ']');
els.each(function(el){
if (el.dom.id == this.id) {
Ext.ux.RadioGroup.superclass.disable.call(this);
}
else {
var e = Ext.getCmp(el.dom.id);
Ext.ux.RadioGroup.superclass.disable.call(e);
}
}, this);
},
enable: function(){
if (!this.rendered) return;
var p = this.el.up('form');//restrict to the form if it is in a form
if (!p) p = Ext.getBody();
var els = p.select('input[name=' + escape(this.el.dom.name) + ']');
els.each(function(el){
if (el.dom.id == this.id) {
Ext.ux.RadioGroup.superclass.enable.call(this);
}
else {
var e = Ext.getCmp(el.dom.id);
Ext.ux.RadioGroup.superclass.enable.call(e);
}
}, this);
},
hide: function(){
if (!this.rendered) return;
this.wrap.hide();
this.wrap.parent().parent().hide();
},
show: function(){
if (!this.rendered) return;
this.wrap.show();
this.wrap.parent().parent().show();
}
});
Ext.reg('ux-radiogroup', Ext.ux.RadioGroup);
发表评论
-
ExtJS Architecture
2011-04-12 10:17 1119website: http://www.slideshare. ... -
ExtJS2.0中使用开始和结束时间的控件 示例
2009-05-25 18:54 2497ExtJS2.0中使用开始和结束时间的控件 示例 效果: ... -
ExtJS grid中如何显示时间
2009-05-12 16:05 5227ExtJS grid中如何显示时间 效果: 实现 ... -
在ExtJS2.0中使用datefield编写开始/结束时间组件
2009-04-08 10:17 3462在ExtJS2.0中使用datefield编写开始/结束时间组 ... -
解决ExtJs分页grid中load数据为空时不能刷新Ext.PagingToolbar信息的问题
2009-03-19 16:43 7067解决ExtJs分页grid中load数据为空时不能刷新Ext. ... -
Ext.plugins.TDGi.tabScrollerMenu插件的使用
2009-03-10 15:47 2904Ext.plugins.TDGi.tabScrollerMen ... -
Ext.ux.TabPanel组件的使用
2009-03-10 11:36 7323Ext.ux.TabPanel组件的使用 效果: HTML ... -
如何在Ext.form.FormPanel中让等待提示绑定在具体的form之上
2009-03-10 09:16 2777如何在Ext.form.FormPanel中让等待提示绑定在具 ... -
Ext.ux.ImageButton的使用(带有图片的按钮) 示例
2009-02-23 16:23 7003Ext.ux.ImageButton的使用( ... -
fieldset多列展示 示例
2009-02-23 16:17 2630fieldset多列展示 示例 效果: HTML源码: &l ... -
Ext.ux.UploadDialog组件的使用 示例
2009-02-18 17:22 7966Ext.ux.UploadDialog组件的使用 示例 效果: ... -
ExtJS TreeCheckNodeUI组件的使用 示例
2009-02-17 16:37 7886ExtJS TreeCheckNodeUI组件的使用 示例 效 ... -
使用localXHR.js让ExtJS docs可以在本地浏览
2009-02-17 11:32 5669使用localXHR.js让ExtJS docs可以在本地浏览 ... -
ExtJS MultiselectItemSelector的使用 示例
2009-02-17 10:30 8530ExtJS MultiselectItemSelector的使 ... -
ExtJS GroupHeaderPlugin的使用 示例
2009-02-17 09:18 6686ExtJS GroupHeaderPlugin的使 ... -
ExtJS中DatetimeMenu组件(包括时、分)的使用 示例
2009-02-16 14:01 2261ExtJS中DatetimeMenu组件(包括时、分)的使用 ... -
ExtJS中editable-column-tree组件的使用 示例
2009-02-16 13:26 5411ExtJS中editable-column-tree组件的使用 ... -
Ext.ux.ThemeCycleButton换肤组件 示例
2009-02-13 14:04 3174Ext.ux.ThemeCycleButton换肤组件 示例 ... -
ExtJS编写的youtube视频播放组件 示例
2009-02-13 11:21 3981ExtJS编写的youtube视频播放组件 示例 效果: ... -
Ext.ux.TabCloseMenu插件的使用(TabPanel右键关闭菜单) 示例
2009-02-13 10:35 14554Ext.ux.TabCloseMenu插件的使用(TabPan ...
相关推荐
radioGroup.setOnCheckedChangeListener(new RadioGroup.OnCheckedChangeListener() { @Override public void onCheckedChanged(RadioGroup group, int checkedId) { for (int i = 0; i < group.getChildCount();...
你可以在`RadioGroup.htm`文档中查看更详细的示例代码和演示效果。 最后,我们提到的`Scripts`和`Extjs311`可能分别代表脚本文件夹和Ext JS 3.1.1版本的库文件。确保引入这些文件才能在页面上正确运行上述代码。 ...
重写 代码如下: //解决checkboxgroup回填数据问题 Ext.override(Ext.form.BasicForm,{ findField : function(id){ var field = this.items.get(id); if(!field){ this.items.each(function(f){ if(f.isXType(...
4.1.8 Ext.form.CheckboxGroup和Ext.form.RadioGroup 4.1.9 Ext.form.field.Trigger触发字段 4.1.10 Ext.form.field.Spinner微调字段 4.1.11 Ext.form.field.Picker拾取器字段 4.1.12 Ext.form.field.ComboBox...
3. **获取选中状态**:可以使用`RadioGroup.getCheckedRadioButtonId()`来获取当前选中的`RadioButton`的ID,然后通过`findViewById()`找到对应的`RadioButton`。 ```java int checkedId = radioGroup....
radioGroup.Items.Add(newItem); ``` 如果需要删除某个item,可以使用Remove或RemoveAt方法,如: ```csharp // 删除指定索引的item radioGroup.Items.RemoveAt(index); // 或者删除指定item radioGroup.Items....
radioGroup.setId(R.id.radio_group); // 添加RadioButton RadioButton radioButton1 = new RadioButton(this); radioButton1.setText("选项1"); radioButton1.setId(1); radioGroup.addView(radioButton1); ...
- `radio`:`Ext.form.Radio`,单选按钮。 - `textarea`:`Ext.form.TextArea`,多行文本输入框。 - `textfield`:`Ext.form.TextField`,单行文本输入框。 - `trigger`:`Ext.form.TriggerField`,触发式输入框...
radioGroup.setOnCheckedChangeListener(new RadioGroup.OnCheckedChangeListener() { @Override public void onCheckedChanged(RadioGroup group, int checkedId) { switch (checkedId) { case R.id.radio_...
radioGroup.setOnCheckedChangeListener(new RadioGroup.OnCheckedChangeListener() { @Override public void onCheckedChanged(RadioGroup group, int checkedId) { // 这里可以获取当前选中的RadioButton的id ...
radioGroup.setOnCheckedChangeListener(new RadioGroup.OnCheckedChangeListener() { @Override public void onCheckedChanged(RadioGroup group, int checkedId) { switch (checkedId) { case R.id....
radioGroup.setOnCheckedChangeListener(new RadioGroup.OnCheckedChangeListener() { @Override public void onCheckedChanged(RadioGroup group, int checkedId) { // 获取选中的RadioButton RadioButton ...
radioGroup.setOrientation(RadioGroup.VERTICAL); ``` 这样,`RadioGroup`将按垂直方向添加新的`RadioButton`,并允许换行。 4. **自定义控件**:`FlexRadioGroup-master`可能是一个开源项目,提供了自定义的`...
多选下拉框在EXT JS中通常通过`Ext.form.CheckboxGroup`或`Ext.form.RadioGroup`类来实现,但在EXT3.2中,实现多选下拉框功能通常会使用`Ext.form.FieldSet`或`Ext.form.ComboBox`的自定义扩展。这类组件提供了复选...
本示例旨在教你如何将这些组件结合使用,创建一个自定义控件,以实现上部导航和主页面导航的功能。以下是关于这三个组件的详细解释以及如何在实际项目中进行集成。 1. **ViewPager**:`ViewPager`是Android支持库中...
- `Ext.form.CheckboxGroup` 和 `Ext.form.RadioGroup`:用于组合复选框和单选框。 - `Ext.form.field.Trigger`:触发字段,常用于下拉搜索框。 - `Ext.form.field.Spinner`:用于数字的微调。 - `Ext.form....
这个工具类写好的可以直接拿来用,可以换行多列使用,不影响单个选择
radioGroup.setOnCheckedChangeListener(new RadioGroup.OnCheckedChangeListener() { @Override public void onCheckedChanged(RadioGroup group, int checkedId) { // 通过checkedId找到被选中的RadioButton并...
radioGroup.setOnCheckedChangeListener(new RadioGroup.OnCheckedChangeListener() { @Override public void onCheckedChanged(RadioGroup group, int checkedId) { switch (checkedId) { case R.id.radio1: /...