全國最多中醫師線上諮詢網站-台灣中醫網
發文 回覆 瀏覽次數:1082
推到 Plurk!
推到 Facebook!

請間 DBLookupComboBox 如何知道它目前指向第幾個item

尚未結案
brook
資深會員


發表:57
回覆:323
積分:371
註冊:2002-07-12

發送簡訊給我
#1 引用回覆 回覆 發表時間:2004-10-08 18:34:07 IP:218.160.xxx.xxx 未訂閱
我知道ComboBox有個ItemIndex可以知道目前選在第幾個Item上, 但DBLookupComboBox沒有這個東東,該如何知道目前選在第幾個Item上呢?
bigdogchina
版主


發表:238
回覆:523
積分:312
註冊:2003-04-28

發送簡訊給我
#2 引用回覆 回覆 發表時間:2004-10-09 17:35:29 IP:211.162.xxx.xxx 未訂閱
brook大大,您好! 小弟思考了一下,一個非常笨的方法(效能好低),還請您看看:

void __fastcall TForm1::DBLookupComboBox1Exit(TObject *Sender)
{
        TStringList *strList = new TStringList();
        AnsiString strText,strTableName;
        int        FindIndex;            strText      = DBLookupComboBox1->Text;
        strTableName = DBLookupComboBox1->ListField;
        ADOTable1->First();
        while(ADOTable1->Eof != true)
        {
            strList->Add(ADOTable1->FieldByName(strTableName)->AsString);
            ADOTable1->Next();
        }
        FindIndex = strList->IndexOf(strText);
        ShowMessage("您選擇的是第"   IntToStr(FindIndex   1)   "行!");
        delete strList;
}
小弟的思考方法是:將當前的DBLookupComboBox中選中的Text讀出,然後利用ListField屬性得到顯示的欄位名,在ADOTable1中將其全部抓入一個StringList中,在TStringList中對比前面讀出的Text來得到其索引位置. 缺點是很明顯的,每做一次動作都要在執行空間上開闢一塊區域,載入全部的資料,很消耗時間。小弟認爲可以將TStringList先保存在Cache上,以後每次都共用相同的資料,或許會好點 <>>是顯示查閱組合方塊,其列示的內容是根據一欄位值而自其他資料集查詢而來的。也可以直接輸入資料,就如標準的資料感知編輯方塊。它重要有>>:列表選項的來源,既指定某個提供資料的>>:要成爲列表選項的表字段,所選擇的欄位元元資料會全部被加入>>:索引欄位元元元,是配合記錄查找功能的 這篇也有些許的相似,供您參考: > ================================= <>人生在勤,不索何獲 <>業精於勤荒於嬉,行成於思毀於隨 <>臨淵羡魚不如退而結網
------
人生在勤,不索何获?
brook
資深會員


發表:57
回覆:323
積分:371
註冊:2002-07-12

發送簡訊給我
#3 引用回覆 回覆 發表時間:2004-10-13 14:12:16 IP:218.160.xxx.xxx 未訂閱
非常感謝bigdogchina版主抽空幫我測試,非常的感謝. 另外我找到一個方法,就是 DBLookupComboBox1->Field->LookupDataSet->FieldByName("編號")->AsInteger;
系統時間:2024-04-29 14:35:03
聯絡我們 | Delphi K.Top討論版
本站聲明
1. 本論壇為無營利行為之開放平台,所有文章都是由網友自行張貼,如牽涉到法律糾紛一切與本站無關。
2. 假如網友發表之內容涉及侵權,而損及您的利益,請立即通知版主刪除。
3. 請勿批評中華民國元首及政府或批評各政黨,是藍是綠本站無權干涉,但這裡不是政治性論壇!