简体   繁体   English

隐藏LookUpEdit中的列(DevExpress)

[英]Hide Columns in LookUpEdit (DevExpress)

I am trying hide all columns of a LookUpEdit control (DevExpress 3rd party) except the DisplayMember (Its functionality should seems as stander ComboBox) 我正在尝试隐藏LookUpEdit控件(DevExpress第三方)的所有列,除了DisplayMember(它的功能应该像stander ComboBox一样)

The Properties.DataSource is a DataTable, so when I want to access to each column for hiding it, programs launches Null ref exception. Properties.DataSource是一个DataTable,所以当我想访问每一列以隐藏它时,程序会启动Null ref异常。

What am I doing wrong? 我究竟做错了什么?

The code: 代码:

If TypeOf Me.Properties.DataSource Is DataTable Then
     Me.Properties.PopulateColumns()
     Dim dt As DataTable = CType(Me.Properties.DataSource, DataTable)

     For Each column As DataColumn In dt.Columns
         If Me.Properties.Columns(column.ColumnName) IsNot Nothing AndAlso column.ColumnName IsNot Me.DisplayMember Then
                Me.Properties.Columns(column.ColumnName).Visible = False
         End If
     Next

End If

Instead of hiding columns you can add only one column that you need: 您可以只添加一个所需的列,而不是隐藏列:

lookUpEdit1.Properties.Columns.Add(New LookUpColumnInfo(lookUpEdit1.Properties.DisplayMember))

Here is example: 这是一个例子:

Dim dataTable As New DataTable()

dataTable.Columns.Add("ID", Type.GetType("System.Int32"))
dataTable.Columns.Add("Name", Type.GetType("System.String"))
dataTable.Columns.Add("Description", Type.GetType("System.String"))

dataTable.Rows.Add(0, "Name0", "Description0")
dataTable.Rows.Add(1, "Name1", "Description1")
dataTable.Rows.Add(2, "Name2", "Description2")

lookUpEdit1.Properties.DataSource = dataTable
lookUpEdit1.Properties.DisplayMember = "Name"
lookUpEdit1.Properties.ValueMember = "ID"

lookUpEdit1.Properties.Columns.Add(New LookUpColumnInfo(lookUpEdit1.Properties.DisplayMember))

To hide a specific column in a lookupedit control of devexpress is: 要在devexpress的lookupedit控件中隐藏特定列,请执行以下操作:

lookUpEdit1.Properties.PopulateColumns();
lookUpEdit1.Properties.Columns[**index**].Visible = false;

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM