Flex Tree 数据过滤
来源:互联网 发布:淘宝达人发帖图片范本 编辑:程序博客网 时间:2024/05/21 10:06
根据用户输入的关键字,在Tree控件中快速的把匹配的数据列出来是个比较好功能。现在发现有两种实现方法,一是如果Tree数据源是ArrayCollection 可以用它的filterFunction来指定一个过滤函数来实现,二是从Tree的初始数据中过滤出新的XML数据。下面的例子用的就是第二种方法,只列出关键语句 从webservice获取xml数据方面的操作都不列出了。
private var xmllist:XMLList;
private var keyword:String;
//过滤数据
public function filterData(keywodr:String):void
{
if(StringUtil.trim(keywodr)!="")
{
this.keyword=keywodr;
var myxml:XML=<node/>;
for(var k:int=0;k<xmllist.length();k++)
{
var tempxml:XML=getXML(new XMLList(xmllist[k]));
if(tempxml.children().length()>0)
{
myxml.appendChild(tempxml);
}
}
this.tree.dataProvider=myxml.children();
}
else //输入关键字为空时为原始数据
{
this.tree.dataProvider=xmllist;
}
}
private function getXML(xmllist:XMLList):XML
{
var xmlChildren:XMLList=xmllist.children(); //子节点
var xml:XML=<categories/>; //返回的xml
if(xmllist.hasOwnProperty("@cd")) xml.@cd=xmllist.@cd;//xml属性
if(xmllist.hasOwnProperty("@STNM")) xml.@STNM=xmllist.@STNM;
for(var i:int=0;i<xmlChildren.length();i++)
{
if(xmlChildren[i].children().length()>0) //有子节点时
{
var xmlGet:XML=getXML(new XMLList(xmlChildren[i])); //递归得到的xml
if(xmlGet.children().length()>0) //有子节点就增加
{
xml.appendChild(xmlGet);
}
}else //无子节点时
{
var temp:String=xmlChildren[i].@STNM;
if(temp.indexOf(this.keyword)>=0)//关键字
{
xml.appendChild(xmlChildren[i]);
}
}
}
return xml;
}
- Flex Tree 数据过滤
- flex 数据过滤
- Flex Tree动态数据
- Flex中datagrid数据过滤
- Flex dataGrid实现数据过滤
- Flex dataGrid实现数据过滤
- flex datagrid拖拽不同类型数据过滤
- FLEX ArrayCollection删除过滤的数据
- easyui的tree加载数据过滤匹配
- Flex 使用ArrayCollection的FilterFunction进行数据过滤
- 即时报表Flex工具条使用之过滤显示数据
- flex 去除Array中的重复数据 过滤重复值
- Flex 使用ArrayCollection的FilterFunction进行数据过滤
- Flex 使用ArrayCollection的FilterFunction进行数据过滤
- Flex Tree
- Flex tree
- 采用数据库为Flex Tree组件的提供数据-前言
- FLex中Tree与JavaScript交互动态加载数据
- json-c(转载)
- 自定义ArcGIS API for Flex 地图提示窗体
- ArcGIS API for Flex实现的实时监控功能
- Flex中显示web页面
- Flex 时间格式化 (转换)
- Flex Tree 数据过滤
- AGS FLEX 求线/面的中心点
- Flex 3.0 国际化
- Flex Tree和其他控件的联动
- Flex对Array中的对象进行排序操作
- RedHat Linux 自动启动脚本设置
- Flex chart设置Legend样式
- 改变Flex DataGrid 行的背景色
- Flex 图表打印