flex中datagrid checkbox全选及单选源码

flex中datagrid checkbox全选及单选源码


<?xml version="1.0" encoding="utf-8"?>

<mx:TitleWindow xmlns:mx="http://www.adobe.com/2006/mxml" layout="absolute" width="632" height="300" showCloseButton="true">
<mx:Script>
<![CDATA[
import mx.controls.Alert;
import mx.collections.ArrayCollection;

 public var data1:ArrayCollection = new ArrayCollection([{id:1,city:'重庆',person:5000},{id:2,city:'北京',person:8000},{id:3,city:'成都',person:52300}]);
     public var data2:ArrayCollection = new ArrayCollection();
     public var allstate:Boolean = false;
     //全选
     public function doselectAll(event:MouseEvent):void
     {
      data2.removeAll();
      allstate = event.target.selected;
       for each (var item in datagrid1.dataProvider) {
        item.selected = allstate;
        if(item.selected){
        data2.addItem(item);
        }
       }
     datagrid2.dataProvider.refresh();
     }
    //单选
    public function doselect(){
     data2.removeAll();
     for each (var item in datagrid1.dataProvider) {
        if(item.selected){
           data2.addItem(item);
        }
       
       }
    }

]]>
</mx:Script>
<!--如果表格加sortableColumns="false"属性,checkbox状态无法更新-->
<mx:DataGrid x="39" y="55" id="datagrid1" dataProvider="{data1}" width="228" >
<mx:columns>

<mx:DataGridColumn headerText="" dataField="id">
 <mx:headerRenderer>
     <mx:Component>
       <mx:HBox verticalAlign="middle">
         <mx:CheckBox toolTip="全选" selected="{outerDocument.allstate}" click="outerDocument.doselectAll(event)"/>
       </mx:HBox>
     </mx:Component>
 </mx:headerRenderer>
 <mx:itemRenderer>
   <mx:Component>
     <mx:HBox  verticalAlign="middle">
       <mx:Script>
<![CDATA[
protected function cb_change_handler(event:Event):void
{
data.selected = !data.selected; //当点击checbox时,改变checked属性状态
}
]]>
</mx:Script>
<mx:CheckBox  selected="{data.selected}" click="outerDocument.doselect()" change="cb_change_handler(event)"/>
     </mx:HBox>
   </mx:Component>
 </mx:itemRenderer>
</mx:DataGridColumn>
<mx:DataGridColumn headerText="编号" dataField="id"/>
<mx:DataGridColumn headerText="城市" dataField="city"/>
<mx:DataGridColumn headerText="人数" dataField="person"/>
</mx:columns>
</mx:DataGrid>
<mx:DataGrid id="datagrid2" x="275" y="55" width="234" dataProvider="{data2}">
<mx:columns>
<mx:DataGridColumn headerText="编号" dataField="id"/>
<mx:DataGridColumn headerText="城市" dataField="city"/>
<mx:DataGridColumn headerText="人数" dataField="person"/>
</mx:columns>
</mx:DataGrid>
</mx:TitleWindow>
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

sencerity

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值