Arhn - архитектура программирования

Как динамически добавлять столбцы в сетку для devexpress datagrid

Я использую сетку devexpress winforms.

Я привязываю данные из набора данных к сетке devexpress.

 dataGrid.MainView.GridControl.DataSource = ds;
 dataGrid.MainView = gridView;
 gridView.BestFitColumns();

Отображение сетки будет таким

 FirstName  LastName    
 Sharp      Eye

Я вызываю событие RowStyle для отображения цвета фона для строк в сетке в зависимости от условия.

Например:

private void gridViewExcel_RowStyle(object sender, DevExpress.XtraGrid.Views.Grid.RowStyleEventArgs e)
{
    GridView View = sender as GridView;
    string firstName = View.GetRowCellDisplayText(e.RowHandle, View.Columns["FirstName"]);

      if (firstName="Sharp")
      {
        e.Appearance.BackColor = Color.Salmon;
        e.Appearance.BackColor2 = Color.White;
      } 
     else
     {
        //I want to append another column in the end to the dataset that is bound to the grid.
        //With an error message...(see below)
     }
}

Выход

 FirstName LastName     Message

 Sharp        Eye      First name doesn't match
09.10.2013

  • Почему бы не добавить еще один столбец в таблицу данных? или добавить UnBoundGridColumn в сетку 09.10.2013

Ответы:


1

Вы не можете условно показать дополнительный столбец в определенных строках. Одним из подходов к вашей проблеме будет добавление столбца «Сообщение» в DataSource, прежде чем вы привяжете его к сетке. А затем измените текст в этом столбце, если в строке есть ошибка.

09.10.2013
  • Другим вариантом может быть отображение значка ошибки ячейки или строки с подсказкой. 09.10.2013
  • см. ссылку для получения дополнительной информации devexpress.com/Support/Center/Example/Details/E1933 09.10.2013

  • 2

    Вы можете создать экземпляр DevExpress.XtraGrid.Columns.GridColumn() во время выполнения.

    Ex :

    DevExpress.XtraGrid.Columns.GridColumn colMessage= newDevExpress.XtraGrid.Columns.GridColumn();
    
    colMessage.Caption = "Message";
    colMessage.FieldName = "<bound datafield>";
    colMessage.Name = "colMessage";
    colMessage.OptionsColumn.AllowEdit = false;
    colMessage.OptionsColumn.FixedWidth = true;
    colMessage.OptionsColumn.ReadOnly = true;
    colMessage.Visible = true;
    colMessage.VisibleIndex = 0;
    colMessage.Width = 80;
    View.Columns.AddRange(newDevExpress.XtraGrid.Columns.GridColumn[] {
                this.colMessage});
    

    Также можно объявить несвязанный столбец и заполнить его событиями gridView.

    09.10.2013

    3

    Я не знаком конкретно с devexpress, но думаю, вам лучше проанализировать свои данные, прежде чем привязывать их к сетке. Когда вызывается gridViewExcel_RowStyle? Вы хотите избежать тяжелой логики, если она вызывается часто.

    Если вам действительно нужна логика здесь, вы должны иметь возможность получить набор данных из связанного источника (или из поля) и добавить столбец по мере необходимости.

    GridView View = sender as GridView;
        string firstName = View.GetRowCellDisplayText(e.RowHandle, View.Columns["FirstName"]);
    
          if (firstName=="Sharp")
          {
            e.Appearance.BackColor = Color.Salmon;
            e.Appearance.BackColor2 = Color.White;
          } 
         else
     {   
    
         DataSet ds = view.DataSource as DataSet;
         if(ds != null)
         {
             //add the column to the table you want if it doesn't exist
         }
     }
    
    09.10.2013
    Новые материалы

    Коллекции публикаций по глубокому обучению
    Последние пару месяцев я создавал коллекции последних академических публикаций по различным подполям глубокого обучения в моем блоге https://amundtveit.com - эта публикация дает обзор 25..

    Представляем: Pepita
    Фреймворк JavaScript с открытым исходным кодом Я знаю, что недостатка в фреймворках JavaScript нет. Но я просто не мог остановиться. Я хотел написать что-то сам, со своими собственными..

    Советы по коду Laravel #2
    1-) Найти // You can specify the columns you need // in when you use the find method on a model User::find(‘id’, [‘email’,’name’]); // You can increment or decrement // a field in..

    Работа с временными рядами спутниковых изображений, часть 3 (аналитика данных)
    Анализ временных рядов спутниковых изображений для данных наблюдений за большой Землей (arXiv) Автор: Рольф Симоэс , Жильберто Камара , Жильберто Кейрос , Фелипе Соуза , Педро Р. Андраде ,..

    3 способа решить квадратное уравнение (3-й мой любимый) -
    1. Методом факторизации — 2. Используя квадратичную формулу — 3. Заполнив квадрат — Давайте поймем это, решив это простое уравнение: Мы пытаемся сделать LHS,..

    Создание VR-миров с A-Frame
    Виртуальная реальность (и дополненная реальность) стали главными модными терминами в образовательных технологиях. С недорогими VR-гарнитурами, такими как Google Cardboard , и использованием..

    Демистификация рекурсии
    КОДЕКС Демистификация рекурсии Упрощенная концепция ошеломляющей О чем весь этот шум? Рекурсия, кажется, единственная тема, от которой у каждого начинающего студента-информатика..