flex DataGrid 标题上放 CheckBox 实现全选
2012-05-15 15:41
423 查看
利用headerRenderer加入checkbox然后这个checkbox调用外部方法实现全选.
附送代码片段,如有不懂可以追问.
<mx:DataGridColumn headerText=" " width="20">
<mx:headerRenderer>
<mx:Component>
<mx:VBox horizontalAlign="center">
<mx:CheckBox id="chball" selected="{outerDocument.ISsel}" change="outerDocument.selectAll(this)" creationComplete="outerDocument.setObjChb(this)"/>
</mx:VBox>
</mx:Component>
</mx:headerRenderer>
<mx:itemRenderer>
<mx:Component>
<mx:VBox width="100%" horizontalAlign="center">
<mx:CheckBox id="cbox" selected="{int(data.chk)}" selectedField="{int(data.chk)}" click="outerDocument.checkClick(this)"/>
</mx:VBox>
</mx:Component>
</mx:itemRenderer>
</mx:DataGridColumn>
//调用的外部方法
public function selectAll(obj:Object):void
{
ISsel=!ISsel;
if (dataArray.length > 0)
{
if (obj.chball.selected == true)
{
for (var i:int=0; i < dataArray.length; i++)
{
dataArray[i].chk=1;
}
for(var i:int = 0; i < dataArray.length;i++){
if(dataArray[i].chk == 1){
//绑定被选中的数据
arr.addItem(dataArray[i]);
}
}
aa.text = "已选择"+dataArray.length+"名";
}else{
for (var j:int=0; j < dataArray.length; j++)
{
dataArray[j].chk=0;
}
aa.text = "已选择"+0+"名";
arr.removeAll();
}
dataArray.refresh();
}
}
public function setObjChb(obj:Object):void
{
this.objChb=obj;
}
附送代码片段,如有不懂可以追问.
<mx:DataGridColumn headerText=" " width="20">
<mx:headerRenderer>
<mx:Component>
<mx:VBox horizontalAlign="center">
<mx:CheckBox id="chball" selected="{outerDocument.ISsel}" change="outerDocument.selectAll(this)" creationComplete="outerDocument.setObjChb(this)"/>
</mx:VBox>
</mx:Component>
</mx:headerRenderer>
<mx:itemRenderer>
<mx:Component>
<mx:VBox width="100%" horizontalAlign="center">
<mx:CheckBox id="cbox" selected="{int(data.chk)}" selectedField="{int(data.chk)}" click="outerDocument.checkClick(this)"/>
</mx:VBox>
</mx:Component>
</mx:itemRenderer>
</mx:DataGridColumn>
//调用的外部方法
public function selectAll(obj:Object):void
{
ISsel=!ISsel;
if (dataArray.length > 0)
{
if (obj.chball.selected == true)
{
for (var i:int=0; i < dataArray.length; i++)
{
dataArray[i].chk=1;
}
for(var i:int = 0; i < dataArray.length;i++){
if(dataArray[i].chk == 1){
//绑定被选中的数据
arr.addItem(dataArray[i]);
}
}
aa.text = "已选择"+dataArray.length+"名";
}else{
for (var j:int=0; j < dataArray.length; j++)
{
dataArray[j].chk=0;
}
aa.text = "已选择"+0+"名";
arr.removeAll();
}
dataArray.refresh();
}
}
public function setObjChb(obj:Object):void
{
this.objChb=obj;
}
相关文章推荐
- WinForm DataGrid 中在 DataGridBoolColumn 的列标题上加一个 CheckBox 实现全选和全不选
- 周末在家闲得慌,整理了一下flex AdvancedDataGrid实现checkBox全选功能
- Flex中DataGrid实现列(包括头部)中加入CheckBox全选功能
- flex datagrid 嵌checkbox实现全选与数据存储(非绑定数据源)
- Flex:用checkBox实现DataGrid所有行的选择(全选)
- flex datagrid 嵌checkbox实现全选与数据存储(非绑定数据源)
- Flex中DataGrid实现列(包括头部)中加入CheckBox全选功能
- 在Flex中简单实现 dataGrid结合CheckBox使项目可选、全选、反选
- Flex中DataGrid实现列(包括头部)中加入CheckBox全选功能 几种实现方法
- JavaScript实现DataGrid中添加CheckBox列(全选与否)
- easyui扩展datagrid-groupview实现支持全选及点击标题收缩
- DataGrid中的添加CheckBox实现全选/单选【原创】
- Flex控件--AdvancedDataGrid实现列头过滤功能(顺便写了Button列、CheckBox列、ComboBox列等)
- javascript实现datagrid客户端checkbox列的全选,反选
- flex中datagrid checkbox全选及单选源码
- [导入]JavaScript实现DataGrid中添加CheckBox列(全选与否)
- 在asp.net中实现datagrid checkbox 全选的方法
- JavaScript实现DataGrid中添加CheckBox列(全选与否)
- JavaScript实现DataGrid中的CheckBox全选与否
- JavaScript实现DataGrid中添加CheckBox列(全选与否)