主题:哪位高手来指导?老大救救我呀!
shangyuguang
[专家分:0] 发布于 2005-10-03 10:16:00
有一窗口 上面有datawindow 和一个sle_ 控件 连上数据后!!
怎么做到我输入一个拼音代码(在单行编辑器上)数窗的数据就相应的到
那一行!比如我输入amxl 输入字母a时那么拼音代码a开头的
就出来了输入到m时am开头的就出来了 直至我想找到的!!数窗的列中有pydm(拼音代码)列。
回复列表 (共4个回复)
沙发
Lucker [专家分:200] 发布于 2005-10-03 15:23:00
你说到的这个问题是一个"增量查询"的问题,一时难以说清楚,我现在比较忙,不过明天早上之前可以给你一满意的答案.
板凳
Lucker [专家分:200] 发布于 2005-10-04 02:51:00
增量查询功能实现的关键有两点,一是单行编辑器能实时响应键盘的输入,捕捉每一个按键,获得其中的文本;二是数据窗口的模糊查询功能,即能够找到列ID左边文本与单行编辑器文本相等的行,这可以用“like”来实现。下面给出具体方法:
1.定义单行编辑器的用户事件ue_enchange,事件的ID为:pbm_enchange。这个事件能响应键盘的输入。
2.在单行编辑器的ue_enchange事件中编写如下脚本:
long ll_found_row
string ls_find
ls_find = ″string(id) like ″ + ″′″ + this.text + ″%′″ //查找条件(左部分与单行编辑器文本相等)
ll_found_row = dw_name.Find(ls_find, 1, dw_name.RowCount()) //查找符合条件的行
if ll_found_row <= 0 then return
dw_name.ScrollToRow(ll_found_row) //滚动到相匹配的行
dw_name.SelectRow(0 , false)
dw_name.SelectRow(ll_found_row , true) //将匹配行加亮显示
3 楼
shangyuguang [专家分:0] 发布于 2005-10-06 16:27:00
谢谢你!lucker
[em5]
4 楼
982 [专家分:10] 发布于 2005-10-22 15:29:00
Lucker 说得很好。
我来回复