Flex 扩展combobox 实现复选功能
前段时间,老大召唤,给个任务,研究一下flex的combobox控件 实现复选功能(flex自带的combobox控件不可以复选),小兵能力有限,哪里可以扩展呀,网上看了别人写的,发现总是有点瑕疵(关键是还没有注释这个是最蛋疼的):
1.静态数据源正常,动态数据源 第一次点击时 没有取到数据,下拉列表为空。
2. ROLL_OVER ROLL_OUT 监听混乱,选择一项后下拉框突然收缩了,或者选择几项下拉框突然收缩了。
3.返回值有误,显示选中的项 与 实际返回选中的项不符
分析:
ROLL_OVER 与 ROLL_OUT 区别:
ROLL_OVER:就是鼠标从外部移入该组件才调用, ROLL_OUT 就是鼠标移到该组件外部才调用
另外 其他两个:MOUSE_OVER 与MOUSE_OUT 区别类似
ROLL_* 与MOUSE_* 的区别是:
MOUSE_*:鼠标 进入/移 出该组件时会调度MOUSE_*事件,即使是从其子组件移到该组件依然会触发该事件
ROLL_* :鼠标从不是其子组件的其余组件中进入该组件时会调度ROLL_*事件
下面是扩展后的代码,修复了上面提到的瑕疵:
必要部分已经加上了注释
MultipleComboBox.cs
package common
{
import flash.events.Event;
import flash.events.MouseEvent; import mx.collections.ArrayCollection;
import mx.controls.ComboBox;
import mx.core.ClassFactory;
import mx.events.FlexEvent;
import mx.events.ListEvent; public class MultipleComboBox extends ComboBox{
private var mouseOut:Boolean=false;
[Bindable]
private var promptText:String=""; //复选框收缩后显示label的值
private var selArr:Array=[]; //复选框选中值集合
private var splitStr:String="/"; //选中多个值 以此分割
public function MultipleComboBox(){
super();
this.addEventListener(FlexEvent.CREATION_COMPLETE,onCreateCompleteHandle);
//多选ComboBox 内嵌CheckBox实现
this.itemRenderer=new ClassFactory(CheckBoxItemRenderer);
}
private function onCreateCompleteHandle(event:FlexEvent):void{
dropdown.allowMultipleSelection=true;
close();
//
mouseOut=false; //置为false
}
//监听鼠标一入一出
private function initListener():void{
if(!dropdown.hasEventListener(MouseEvent.ROLL_OVER))
dropdown.addEventListener(MouseEvent.ROLL_OVER,onRollOverHandle);
if(!dropdown.hasEventListener(MouseEvent.ROLL_OUT))
dropdown.addEventListener(MouseEvent.ROLL_OUT,onRollOutHandle);
}
private function onRollOverHandle(event:MouseEvent):void{
mouseOut=false;
}
private var changeEvent:ListEvent;
//ROLL_OUT 更改选中值集合
private function onRollOutHandle(event:MouseEvent):void{
var list:ArrayCollection=ArrayCollection(this.dataProvider);
mouseOut=true;
var selectedStr:String = ""; //复选框收缩后的label,此处以"/"分割显示选中的值
selArr=[];//每次清空selArr保存的值
for each(var obj:Object in list) //遍历数据源,向selArr数组添加状态selected=true(选中)的值
{
if(obj.selected){
selectedStr += obj.Code+this.splitStr;
selArr.push(obj);
}
}
this.selectedItems=selArr;
this.promptText = selectedStr.substring(,selectedStr.length -) ; close(); //鼠标移出 收缩
//
mouseOut=false; //置为false changeEvent= new ListEvent( ListEvent.CHANGE )
dispatchEvent( changeEvent);
trace(this.text);
}
//ComboBox 带有selectedItems属性 但只实现selectedItem,此处实现selectedItems
public function set selectedItems(value:Array):void{
if (dropdown){
dropdown.selectedItems=value;
}
this.selArr=value;
} [Bindable("change")]
public function get selectedItems():Array{
return selArr;
}
override public function close(trigger:Event=null):void{
//initListener();
if (mouseOut){
super.close(trigger);
}
this.textInput.text=promptText;
this.toolTip = promptText;
initListener();//此处需要从上面注释处调整到这里,
//因为 CheckBoxItemRender中的 this.addEventListener(Event.CHANGE,onClickCheckBox)监听导致
//基数次单击时mouseOut=true; 直接下拉框收缩
}
override public function set prompt(value:String):void{
promptText=value;
}
public function set split(value:String):void
{
this.splitStr=value;
}
public function get split():String
{
return splitStr;
}
}
}
CheckBoxItemRenderer.cs:
package common
{
import flash.events.Event; import mx.collections.ArrayCollection;
import mx.controls.CheckBox;
import mx.controls.List;
import mx.utils.ArrayUtil; import configuration.FormatConfig; public class CheckBoxItemRenderer extends CheckBox{ /**存储当前列数据对象**/
private var currData:Object; public function CheckBoxItemRenderer(){
super();
this.addEventListener(Event.CHANGE,onClickCheckBox);
} override public function set data(value:Object):void{
if(value !=null)
{
this.selected = value.selected;
this.currData = value;
//此处CheckBox label显示code+name 可根据需要置
this.label=value.Code+" "+value.Name;
}
else
{
this.label=null;
}
}
//此属性可设置 数据源任意一项不可选 (enabled)
override public function set enabled(value:Boolean):void{ //
if(currData){
value=currData.enabled==false?false:true;
}
super.enabled=value;
}
/*更改被选中项的状态selected=true*/
private function onClickCheckBox(e:Event):void{
var list:ArrayCollection=ArrayCollection(List(this.parent.parent).dataProvider);//获取数据源
for each(var obj:Object in list)
{
//label的值为数据源中code + name 拼接的 所以此处判断某一项是否被选中的条件看上去有点怪
if((obj.Code+" "+obj.Name)==this.label){
if(this.selected){
obj.selected=true; //选中状态selected=true
}else{
obj.selected=false; //为选好
}
//break;
}
}
}
}
}
由于扩展的不够通用,所以使用的时候稍微做点处理
应用 Temp.mxml文件
<?xml version="1.0" encoding="utf-8"?>
<mx:Module xmlns:fx="http://ns.adobe.com/mxml/2009"
xmlns:s="library://ns.adobe.com/flex/spark"
xmlns:mx="library://ns.adobe.com/flex/mx"
xmlns:common="common.*"
creationComplete="module_creationCompleteHandler(event)"
xmlns:mywebservice="services.mywebservice.*">
<fx:Script>
<![CDATA[
import mx.rpc.soap.WebService;
import spark.components.Scroller;
import spark.components.VScrollBar;
import spark.events.IndexChangeEvent; [Bindable]
private var datacbbSource:ArrayCollection; private function ShowSelectItems2():void{
info2.text="";
info2.text+="选中了 "+myCombox2.selectedItems.length+" 个选项!\n";
for each(var item:Object in myCombox2.selectedItems){
info2.text+=ObjectUtil.toString(item)+"\n";
}
} var num=;
private function module_creationCompleteHandler(event:FlexEvent):void
{
GetDataResult.token = mywebservice.GetData(); //获取数据源
} [Bindable]
private var dataGrideSource:ArrayCollection; protected function GetAllShopsResult_resultHandler(event:ResultEvent):void
{
// TODO Auto-generated method stub
var result:ArrayCollection=event.result as ArrayCollection;
if (result == null || result.length == )
{
return;
}
this.datacbbSource=new ArrayCollection();
for each(var item in result)
{
datacbbSource.addItem({Code:item.Code,Name:item.Name,selected:false});
}
} ]]>
</fx:Script>
<fx:Declarations>
<s:CallResponder id="GetDataResult" result="GetDataResult_resultHandler(event)" />
<shopservice:MyWebService id="mywebService" />
</fx:Declarations>
<s:VGroup width="100%" height="100%" paddingLeft="" paddingRight="" paddingBottom="" paddingTop="">
<s:HGroup width="100%" color="black" verticalAlign="middle" height="">
<common:MultipleComboBox width="" id="myCombox2" split=";"
prompt="请选择" >
<s:ArrayCollection list="{datacbbSource}"/>
</common:MultipleComboBox>
<mx:Text id="info2"/>
<s:Button label="点击查看选择数据" click="ShowSelectItems2()"/>
</s:HGroup>
</s:VGroup>
</mx:Module >
运行结果就不上图了,下面这段
for each(var item in result)
{
datacbbSource.addItem({Code:item.Code,Name:item.Name,selected:false});
}
对数据源做了处理,强制转换成含有Code,Name,selected(默认值false)三个属性的对象,因为在CheckBoxItemRenderer.cs 和MultipleComboBox.cs文件中使用到的参数直接使用到了Code,Name,selected属性。
最后虽然最终这个没有应用到项目中,为了以后用到时方便,记录一下。
继续充电中。。。。
扩展代码参考:http://liu-yi126.iteye.com/blog/1305494
Flex 扩展combobox 实现复选功能的更多相关文章
- QT 创建一个具有复选功能的下拉列表控件
最近研究了好多东西,前两天突然想做一个具有复选功能的下拉列表框.然后在网上"学习"了很久之后,终于发现了一个可以用的,特地发出来记录一下. 一.第一步肯定是先创建一个PROJECT ...
- QComboBox实现复选功能(三种方法:嵌套QListWidget, 设置QStandardItemModel, 设置Delegate)
今天介绍一下一个小东西 — 如何让QComboBox实现复选功能? 需求: 下拉列表有复选功能 不可编辑 显示所有选中项 关于QComboBox的复选功能有几种方案: QStandardIte ...
- QComboBox实现复选功能
需求: 下拉列表有复选功能 不可编辑 显示所有选中项 关于QComboBox的复选功能有几种方案: QStandardItemModel + QStandardItem QListWidget + ...
- duilib 修复CTreeViewUI复选功能判断不准确的bug
转载请说明出处,谢谢~~:http://blog.csdn.net/zhuhongshu/article/details/42265209 CTreeViewUI里面自带了复选的功能,但是复选功能存在 ...
- 在QComboBox的基础上实现复选功能
这个是最近的一个项目上需要实现的功能.要求如下: 下拉列表的项目可以多选 显示框不能编辑 所选中的项目在显示框中出现 下面根据网上的提示代码(参照博客 一去二三里),主要实现如下代码(与参照略有不同) ...
- combobox添加复选框
问题: 需求提出要做一个下拉框可以多选的 解决方案: //机构树 function initOrgTree() { $('#reportOrg').combobox({ width: 200, edi ...
- 为DataGridView控件实现复选功能
实现效果: 知识运用: DataGridViewCheckBoxColumn类 实现代码: private class Fruit { public int Price { get; set; } p ...
- 个人永久性免费-Excel催化剂功能第58波-批量生成单选复选框
插件的最大威力莫过于可以把简单重复的事情批量完全,对日常数据采集或打印报表排版过程中,弄个单选.复选框和用户交互,美观的同时,也能保证到数据采集的准确性,一般来说用原生的方式插入单选.复选框,操作繁琐 ...
- Qt之QTableView添加复选框(QAbstractTableModel)
简述 使用QTableView,经常会遇到复选框,要实现一个好的复选框,除了常规的功能外,还应注意以下几点: 三态:不选/半选/全选 自定义风格(样式) 下面我们介绍一下常见的实现方式: 编辑委托. ...
随机推荐
- iOS 无限轮播图的两种实现
首先说一下实现的思想: 用UIScrollView实现,在scrollView上添加3个UIImageView,分别用来显示上一张图片,当前显示的图片,下一张图片.scrollView在不滑动的时候永 ...
- HDU 5900 - QSC and Master [ DP ]
题意: 给n件物品,有key和value 每次可以把相邻的 GCD(key[i], key[i+1]) != 1 的两件物品,问移除的物品的总value最多是多少 key : 1 3 4 2 移除3 ...
- MFC中使用ADO方式连接数据库
文章转自:http://blog.sina.com.cn/s/blog_a43aba5601014z8h.html 一.数据库操作准备 1.导入ADO动态链接库 在工程的stdafx.h中加入如下语句 ...
- js迭代器模式
在迭代器模式中,通常有一个包含某种数据的集合的对象.该数据可能储存在一个复杂数据结构内部,而要提供一种简单 的方法能够访问数据结构中的每个元素. 实现如下: //迭代器模式 var agg = (fu ...
- IntelliJ IDEA启动web项目时突然变慢的原因
在使用IntelliJ IDEA开发web项目过程中,有两次项目启动非常慢,大约要200s的时间: 第一次忘记是怎么解决的,第二次出现后,我就直接重新下载了代码,然后部署,启动,时间有恢复正常,只用了 ...
- jQuery 文字截取
HTML <div class="summary"> <p class="news">业内知道,当赵科林“过档”联想之初,恰逢联想 ...
- 前端jquery实现点击图片弹出大图层(且滚动鼠标滑轮图片缩放)
<img src="{$vo.photo}" height="50px" onclick="showdiv({$i});"> & ...
- Hdu1092
#include <stdio.h> int main() { ; while(scanf("%d",&n)){ ) {;} else{ int i,a; ;i ...
- myeclipse中java文件头注释格式设置
转载:http://www.blogjava.net/yxhxj2006/archive/2014/01/14/408940.html myeclipse中java文件头注释格式设置 windows ...
- [POJ] 3264 Balanced Lineup [ST算法]
Balanced Lineup Time Limit: 5000MS Memory Limit: 65536K Total Submissions: 34306 Accepted: 16137 ...