flex 在表格(DataGrid)中搜索

虽然从数据库中查询的数据返回到前台时一般做了分页,如果表格的列较多时,要看数据也不太容易,只能凭肉眼来找了。我们可以自己去遍历表格来找到自己想要的数据,找到后再将找到的行设置为当前选中的状态。如果表格行数较多时,假设找到了需要的数据,并将找到的行设置为选中行,但是由于表格不会自动滚动到找到的那一行,所以有时你还以为没找到呢,不过好在列表类都提供了ScrollToIndex方法,这样就好办了。
对于查找方法,虽然DataGrid也提供了一个方法findString(...),但是这个方法只能精确查找表格中某个单元格的数据,所以想要模糊查找的话还不太方便,所以干脆自己遍历数据查一遍得了,还可以支持模糊查询,下面是示例代码:
//假设s是要查找的字符串,grid是DataGrid组件
var idx:int = -1;
for each(var item:Object in grid.dataProvider){
idx++;
for each(var col:DataGridColumn in grid.columns){
if(col.dataField !=null && String(item[col.dataField]).indexOf(s)!=-1){
grid.selectedItem = item;
grid.scrollToIndex(idx);//将当前行滚动到可视范围内
return;
}
}
}
条件col.dataField !=null是防止表格中有的列没有设置dataField属性,例如对于以CheckBox显示的列你可能没设置dataField属性
条件String(item[col.dataField]).indexOf(s)!=-1检查当前行、列中是否包含字符串s
找到就把表格的选中行设置为找到的那条,并滚动到可视范围内(如果这条数据不在可见范围之内)
上面的代码是找到第一个符合条件的就退出来了,进一步的功能是搜索多条符合条件的数据,并以列表的方式列出来,然后你单击再去定位到指定的行,类似UltraEdit的搜索功能了。

转:http://hi.baidu.com/half_cup_coffee/blog/item/1b261182528736b66d811986.html

Flex 搜索定位DataGrid里的数据

实现的功能:
在输入框中输入你要找的城市(city)名,点击Search City按钮,然后调用了searchCity()进行搜索并自动滚屏到匹配项
<?xml version="1.0" encoding="utf-8"?>
<!--搜索定位,编辑单元格功能-->
<mx:Application xmlns:mx="http://www.adobe.com/2006/mxml<wbr>" layout="vertical" creationComplete="http_test.send();"&gt;<br> &lt;mx:HTTPService id="http_test" <br> url="/flex_xml/date.xml" <br> result="onResult();"&gt; <br> &lt;/mx:HTTPService&gt;<br> &lt;mx:Script&gt;<br> &lt;![CDATA[<br> import mx.controls.Button;<br> import mx.collections.SortField;<br> import mx.collections.ArrayCollection;<br> import mx.collections.Sort;<br> import mx.collections.IViewCursor;<br> [Bindable]<br> var datas:ArrayCollection;<br> var cursor:IViewCursor;<br> private function onResult():void{<br> var sort:Sort=new Sort();<br> sort.fields=[new SortField("city",true)];<br> this.datas=http_test.lastResult.blog.channel.item;<br> this.datas.sort=sort;<br> this.datas.refresh();<br> this.cursor=this.datas.createCursor();<br> }<br> private function searchCity():void{<br> if(search_city.text!=""){<br> if(this.cursor.findFirst({city:search_city.text})){<br> var idx:int=this.datas.getItemIndex(this.cursor.current);<br> this.http_dataGird.scrollToIndex(idx);<br> this.http_dataGird.selectedItem=this.cursor.current;<br> }<br> }<br> }<br> ]]&gt;<br> &lt;/mx:Script&gt;<br><br> &lt;mx:Panel title="{http_test.lastResult.blog.channel.title}" width="90%" height="90%"&gt;<br> &lt;mx:Form&gt;<br> &lt;mx:FormItem label="Search"&gt;<br> &lt;mx:TextInput id="search_city"/&gt;<br> &lt;/mx:FormItem&gt;<br> &lt;mx:FormItem&gt;<br> &lt;mx:Button label="Search City" click="searchCity()"/&gt;<br> &lt;/mx:FormItem&gt;<br> &lt;/mx:Form&gt;<br> &lt;mx:DataGrid id="http_dataGird" dataProvider="{datas}" editable="true" width="100%" height="50%"&gt;<br> &lt;mx:columns&gt;<br> &lt;mx:DataGridColumn headerText="标题" dataField="title"/&gt;<br> &lt;mx:DataGridColumn headerText="作者" dataField="author"/&gt;<br> &lt;mx:DataGridColumn headerText="类型" dataField="category"/&gt;<br> &lt;mx:DataGridColumn headerText="城市" dataField="city"/&gt;<br> &lt;/mx:columns&gt;<br> &lt;/mx:DataGrid&gt;<br> &lt;/mx:Panel&gt;<br> &lt;/mx:Application&gt;<br> 转:<a href="http://zwh910621.iteye.com/blog/550440" target="_blank">http://zwh910621.iteye.com/blog/55044</a></wbr>

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值