Ext.form.CheckboxGroup和Ext.form.RadioGroup RadioGroup的获取值和赋值

Ext.form.CheckboxGroup和Ext.form.RadioGroup

Ext.form.RadioGroup默认值:

    { boxLabel: 'Item 2', name: 'rb', inputValue: '2', checked: true},
  
  
 

Extjs中RadioGroup的获取值和赋值

标签: extjsfunction
  11033人阅读  评论(1)  收藏  举报
  分类:

[javascript]  view plain  copy
  1. Ext.override(Ext.form.RadioGroup, {     
  2.     getValue: function(){     
  3.         var v;     
  4.         if (this.rendered) {     
  5.             this.items.each(function(item){     
  6.                 if (!item.getValue())      
  7.                     return true;     
  8.                 v = item.getRawValue();     
  9.                 return false;     
  10.             });     
  11.         }     
  12.         else {     
  13.             for (var k in this.items) {     
  14.                 if (this.items[k].checked) {     
  15.                     v = this.items[k].inputValue;     
  16.                     break;     
  17.                 }     
  18.             }     
  19.         }     
  20.         return v;     
  21.     },     
  22.     setValue: function(v){     
  23.         if (this.rendered)      
  24.             this.items.each(function(item){     
  25.                 item.setValue(item.getRawValue() == v);     
  26.             });     
  27.         else {     
  28.             for (var k in this.items) {     
  29.                 this.items[k].checked = this.items[k].inputValue == v;     
  30.             }     
  31.         }     
  32.     }     
  33. });    
  34.   
  35. //由于使用loadRecord()方法无法为radiogroup赋值 所以加上以上代码  
  36.   
  37.   
  38. var record = Ext.data.Record.create([  
  39.     {name: "rg",mapping:"rg"},  
  40. ]);  
  41.   
  42. var myNewRecord = new record ({rg:"2"});  
  43.   
  44.    
  45.   
  46.    
  47.   
  48. var radiogroup= new Ext.form.RadioGroup({  
  49.                 fieldLabel : "radioGroup",  
  50.                 items : [{  
  51.                             boxLabel : '是',  
  52.                             inputValue : "1",  
  53.                             name : "rg",  
  54.                             checked : true  
  55.                         }, {  
  56.                             boxLabel : '否',  
  57.                             name : "rg",  
  58.                             inputValue : "2"  
  59.                         }]  
  60.             });  
  61.   
  62. var _formpanel = new Ext.form.FormPanel({  
  63.         labelAlign : "right",  
  64.         labelWidth : 150,  
  65.         loadMask : true,  
  66.   renderTo:Ext.getBody(),  
  67.         frame : true,  
  68.         defaults : {  
  69.             width : 150  
  70.         },  
  71.         items : [radiogroup],  
  72.         buttonAlign : "center",  
  73.         buttons : [{  
  74.             text : "获取radioGroup值",  
  75.             handler : function() {  
  76.                 alert(_formpanel.getForm().getValues()["rg"] );  
  77.   
  78.             alert(_formpanel.getForm().getValues().rg);  
  79.              alert(radiogroup.getValue());//三种方式获取所选值  
  80.             }  
  81.         },{  
  82.             text : "Set radioGroup值2",  
  83.             handler : function() {  
  84.                radiogroup.setValue(2);//把否选中  
  85.             }  
  86.         },{  
  87.             text : "Set radioGroup值1",  
  88.             handler : function() {  
  89.                _formpanel.findByType("radiogroup")[0].setValue(1);//把是选中  
  90.             }  
  91.         },{  
  92.             text : "loadRecord赋值方式",  
  93.             handler : function() {  
  94.                _formpanel.form.loadRecord(myNewRecord);//把否选中  
  95.             }  
  96.         }]]  
  97.     });  

alert(_formpanel.getForm().getValues()["rg"] );

alert(_formpanel.getForm().getValues().rg); alert(radiogroup.getValue());//三种方式获取所选值

 

       {             text : "Set radioGroup值2",             handler : function() {                radiogroup.setValue(2);//把否选中             }         },{             text : "Set radioGroup值1",             handler : function() {                _formpanel.findByType("radiogroup")[0].setValue(1);//把是选中             }         },{             text : "loadRecord赋值方式",             handler : function() {                _formpanel.form.loadRecord(myNewRecord);//把否选中         }        

1、Ext.form.CheckboxGroup主要配置

配置项 类型 说明
allowBlank Boolean 设置是否必须选中至少一项,true表示可以不选,false表示不能为空,至少选中一项,默认为true。
blankText String 当allowBlank设置为false,并且没有选中任何复选框时的提示错误消息
columns String/Number/Array

设置列数量,

有效值包括:

“auto”:自动平分字段容器的宽度

Number:指定列数

Array指定列宽的数组,可以使用整数和浮点数。

items Array 复选框或复选框配置对象的数组

2、Ext.form.CheckboxGroup示例

代码:

复制代码
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head runat="server">
    <title>CheckboxGroup和RadioGroup示例</title>
    <link href="ext-4.0.7-gpl/resources/css/ext-all.css" rel="stylesheet" type="text/css" />
    <script src="ext-4.0.7-gpl/bootstrap.js" type="text/javascript"></script>
    <script type="text/javascript">
        Ext.onReady(function () {
            new Ext.form.Panel({
                title: "CheckboxGroup和RadioGroup示例",
                bodyStyle: "padding:5",
                frame: true,
                height: 150,
                width: 300,
                renderTo: Ext.getBody(),
                defaults: {
                    labelSeparator: "",
                    labelWidth: 80,
                    width: 250,
                    labelAlign: "left"
                },
                items: [{
                    xtype: "radiogroup",
                    fieldLabel: "性别",
                    columns: 2,
                    items: [
                        { boxLabel: "", name: "sex", inputValue: "male" },
                        { boxLabel: "", name: "sex", inputValue: "female" }
                    ]
                }, {
                    xtype: "checkboxgroup",
                    fieldLabel: "爱好",
                    columns: 3,
                    items: [
                        { boxLabel: "游泳", name: "swim" },
                        { boxLabel: "散步", name: "walk" },
                        { boxLabel: "阅读", name: "read" },
                        { boxLabel: "游戏", name: "game" },
                        { boxLabel: "电影", name: "movie" }
                    ]
                }]
            });
        });
    </script>
</head>
<body>
</body>
</html>
复制代码

效果图:

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值