




版權說明:本文檔由用戶提供并上傳,收益歸屬內容提供方,若內容存在侵權,請進行舉報或認領
文檔簡介
第Winform開發中使用下拉列表展示字典數據的幾種方式在Winform開發中中,我們為了方便客戶選擇,往往使用系統的字典數據選擇,畢竟選擇總比輸入來的快捷、統一,一般我們都會簡單封裝一下,以便方便對控件的字典值進行展示處理,本篇隨筆介紹DevExpress控件的幾種常見的字典綁定展示方式,希望我們在實際WInform項目中使用到。
1、常規下拉列表的處理
常規的處理方式,可能會使用ComboBoxEdit控件來承載下拉列表,下拉列表的值可以是固定的列表,也可以來自字典的方式,具體根據實際情況而定,大概的效果如下所示。
單擊下拉列表,會展示一些常規的字典項目,如下效果所示。
如果使用控件原始方式,我們綁定控件的下拉列表值的做法如下所示。
combo.Properties.BeginUpdate();//可以加快
combo.Properties.Items.Clear();
combo.Properties.Items.AddRange(itemList);
combo.Properties.EndUpdate();//可以加快
不過我們一般傾向于高效率的界面處理,一般會編寫各類型的界面控件的擴展函數用于快速處理。
不同類型的控件我們用一個獨立的擴展文件來處理,這樣方便維護的同時,也方便借鑒完善。
例如對于上面的控件,我們的綁定方法的擴展函數如下所示。
///summary
///綁定下拉列表控件為指定的數據字典列表
////summary
///paramname="combo"下拉列表控件/param
///paramname="itemList"數據字典列表/param
///paramname="defaultValue"控件默認值/param
///paramname="emptyFlag"是否加入空值選項/param
publicstaticvoidBindDictItems(thisComboBoxEditcombo,ListCListItemitemList,stringdefaultValue,boolemptyFlag=true)
combo.Properties.BeginUpdate();//可以加快
combo.Properties.Items.Clear();
combo.Properties.Items.AddRange(itemList);
if(emptyFlag)
combo.Properties.Items.Insert(0,newCListItem(""));
if(itemList.Count0)
if(!string.IsNullOrEmpty(defaultValue))
combo.SetComboBoxItem(defaultValue);
else
combo.SelectedIndex=0;
combo.Properties.EndUpdate();//可以加快
}
其中方法增加了一些默認值以及是否追加空白項目的處理。
當然,我們為了適應各種數據源的綁定方式,我們重載了很多不同的函數處理,如下截圖所示。
當然對于其他同類型的下列列表控件也是這樣處理即可。這樣界面上,我們就可以指定調用綁定的處理操作了
privatevoidInitDictItem()
this.txtManufacture.Items.Clear();
this.txtManufacture.Items.AddRange(DictItemUtil.GetDictByDictType("供貨商"));
this.txtBigType.Items.Clear();
this.txtBigType.Items.AddRange(DictItemUtil.GetDictByDictType("備件屬類"));
}
或者,我們可以根據字典的類型,來進一步做一個擴展函數,來簡化綁定的處理。
///summary
///綁定下拉列表控件為指定的數據字典列表
////summary
///paramname="control"下拉列表控件/param
///paramname="dictTypeName"數據字典類型名稱/param
///paramname="defaultValue"控件默認值/param
///paramname="emptyFlag"是否添加空行/param
publicstaticvoidBindDictItems(thisComboBoxEditcontrol,stringdictTypeName,stringdefaultValue,boolemptyFlag=true)
Dictionarystring,stringdict=BLLFactoryDictData.Instance.GetDictByDictType(dictTypeName);
ListCListItemitemList=newListCListItem
foreach(stringkeyindict.Keys)
itemList.Add(newCListItem(key,dict[key]));
control.BindDictItems(itemList,defaultValue,emptyFlag);
}
使用了這些簡化的擴展函數,我們可以對系統的字典,根據字典類型來進行綁定了。
privatevoidInitDictItem()
this.txtManufacture.BindDictItems("供貨商");
this.txtSearchManufacture.BindDictItems("供貨商");
this.txtSearchDept.BindDictItems("部門");
}
如上代碼所示,簡化了很多處理,就一個函數就可以綁定了系統字典類型的下拉列表了。
2、帶序號的GridLookUpEdit下拉列表
有時候,我們在一些常見的系統里面,經常看到一些帶有序號的下拉列表,其實里面就是一個GridControl的控件,我們只需要賦值對應的列表數據源,以及設置顯示的列內容,并重寫下序號的展示處理就可以實現了。
我們先來看看實際的效果。
上面的列表是一個GridControl的內在控件,我們使用這個GridLookUpEdit下拉列表控件的時候,設置好GridControl的數據源和顯示的列就基本上可以了。
//綁定數據源和顯示的內容、隱藏值
this.txtProjectList.Properties.DataSource=list;
this.txtProjectList.Properties.ValueMember="Value";
this.txtProjectList.Properties.DisplayMember="Text";
//設置Grid顯示的列信息
varcolumns=newListLookUpColumnInfo()
newLookUpColumnInfo("Value","顯示名稱")
for(inti=0;icolumns.Count;i++)
this.txtProjectList.Properties.View.CreateColumn(columns[i].FieldName,columns[i].Caption,
columns[i].Width,true,UnboundColumnType.Bound,DefaultBoolean.False,FixedStyle.None);
//其他屬性設置
this.txtProjectList.Properties.ImmediatePopup=true;
this.txtProjectList.Properties.TextEditStyle=TextEditStyles.Standard;
this.txtProjectList.Properties.PopupWidthMode=DevExpress.XtraEditors.PopupWidthMode.ContentWidth;
//設定列表的序號的寬度和顯示文本
this.txtProjectList.Properties.View.IndicatorWidth=40;
this.txtProjectList.Properties.View.CustomDrawRowIndicator+=(s,e)=
if(e.Info.IsRowIndicatore.RowHandle=0)
e.Info.DisplayText=(e.RowHandle+1).ToString();
};
那么如果我們需要使用擴展函數來簡化實際的代碼,那么應該如何封裝這個GridLookupEdit的下列控件呢,我們編寫的擴展函數代碼如下所示。
///summary
///綁定控件的數據源
////summary
///paramname="lookup"控件對象/param
///paramname="dataSource"數據源/param
///paramname="displayMember"顯示字段/param
///paramname="valueMember"值字段/param
///paramname="showRowIndicator"是否顯示序號/param
///paramname="lookUpColumnInfos"顯示的列/param
///returns/returns
publicstaticobjectBindDictItems(thisGridLookUpEditlookup,objectdataSource,stringdisplayMember,stringvalueMember,boolshowRowIndicator=true,paramsLookUpColumnInfo[]lookUpColumnInfos)
lookup.Properties.DataSource=dataSource;
lookup.Properties.DisplayMember=displayMember;
lookup.Properties.ValueMember=valueMember;
lookup.Properties.View.Columns.Clear();
for(inti=0;ilookUpColumnInfos.Length;i++)
lookup.Properties.View.CreateColumn(lookUpColumnInfos[i].FieldName,lookUpColumnInfos[i].Caption,
lookUpColumnInfos[i].Width,true,UnboundColumnType.Bound,DefaultBoolean.False,FixedStyle.None);
lookup.Properties.ImmediatePopup=true;
lookup.Properties.TextEditStyle=TextEditStyles.Standard;
if(showRowIndicator)
lookup.Properties.View.IndicatorWidth=40;
//重寫序號顯示,默認不顯示數值
lookup.Properties.View.CustomDrawRowIndicator+=(s,e)=
if(e.Info.IsRowIndicatore.RowHandle=0)
e.Info.DisplayText=(e.RowHandle+1).ToString();
returndataSource;
}
這樣處理后,界面上簡化了不少代碼,如下使用代碼所示。
varlist=DictItemUtil.GetDictByDictType("備件類別");
varcolumns=newListLookUpColumnInfo()
newLookUpColumnInfo("Value","顯示名稱")
this.txtProjectList2.BindDictItems(list,"Tex
溫馨提示
- 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
- 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯系上傳者。文件的所有權益歸上傳用戶所有。
- 3. 本站RAR壓縮包中若帶圖紙,網頁內容里面會有圖紙預覽,若沒有圖紙預覽就沒有圖紙。
- 4. 未經權益所有人同意不得將文件中的內容挪作商業或盈利用途。
- 5. 人人文庫網僅提供信息存儲空間,僅對用戶上傳內容的表現方式做保護處理,對用戶上傳分享的文檔內容本身不做任何修改或編輯,并不能對任何下載內容負責。
- 6. 下載文件中如有侵權或不適當內容,請與我們聯系,我們立即糾正。
- 7. 本站不保證下載資源的準確性、安全性和完整性, 同時也不承擔用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。
評論
0/150
提交評論