【问题标题】:Hide Columns in LookUpEdit (DevExpress)在 LookUpEdit (DevExpress) 中隐藏列
【发布时间】:2014-10-07 02:15:05
【问题描述】:

我正在尝试隐藏 LookUpEdit 控件(DevExpress 第 3 方)的所有列,但 DisplayMember 除外(它的功能应该看起来像标准组合框)

Properties.DataSource 是一个 DataTable,所以当我想访问每一列以隐藏它时,程序会启动 Null ref 异常。

我做错了什么?

代码:

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

【问题讨论】:

  • 检查这个 devexpress.com/Support/Center/Question/Details/Q401110

标签: vb.net datatable devexpress


【解决方案1】:

您可以只添加您需要的一列,而不是隐藏列:

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

示例如下:

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))

【讨论】:

    【解决方案2】:

    在 devexpress 的查找编辑控件中隐藏特定列是:

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

    【讨论】:

      猜你喜欢
      • 1970-01-01
      • 1970-01-01
      • 2019-08-06
      • 1970-01-01
      • 2011-01-13
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      相关资源
      最近更新 更多