Как получить датируемые видимые столбцы Индекс для сохранения состояний в базе данных - PullRequest
0 голосов
/ 17 июня 2019

Я хочу получить общее имя видимых столбцов при нажатии кнопки, чтобы сохранить состояния в базе данных.

Пример - colName - Col1, Col2, Col3, Col4, Col8, Col9

После сохранения имени столбца в базе данных, когда пользователь вернется к этой таблице, он сможет видеть только те столбцы, которые он сохранил вбаза данных.

Когда пользователь возвращается, столбцы, которые отображаются с именем столбца - Col1, Col2, Col3, Col4, Col8, Col9

Я нашел эти функции для столбцаскрыть / показать динамически -

Показать столбец oTable.fnSetColumnVis(item, true,false);

скрыть столбец oTable.fnSetColumnVis(item, false,false);

Вывод

  1. Как можноЯ получаю общий список имен видимых столбцов в таблице данных?

  2. Когда пользователь снова войдет в систему, он сможет видеть только те столбцы, которые он сохранил в прошлый раз?

Любой вклад будет полезен, спасибо.

Ответы [ 2 ]

1 голос
/ 18 июня 2019

Как получить полный список видимых столбцов в таблице данных?

Расширение ответа @Aswin Kumar

let dataTable = $('#example').DataTable({
  "columnDefs": [
    { "visible": false, "targets": [1] },
    { "visible": false, "targets": [4] },
    { "visible": false, "targets": [5] },
  ]
});

let result = dataTable.columns().visible().reduce((a, v, i) => v ? [...a, i] : a, [])

console.log(result) // Gives you index list of all the visible columns

Когда пользователь снова войдет в систему, он должен иметь возможность получать только те индексы, которые он сохранил в прошлый раз?

Это может быть немного сложно.

Вам нужно сохранить значение каждого столбца в базе данных и взагрузка таблицы получить эти значения и использовать их для отображения столбцов

что-то вроде этого

table.columns( [ 0, 1, 2, 3 ] ).visible( false, false );

Подробнее Подробности здесь

Редактировать 1:

Получить все видимые столбцы Имя и индекс.

function get_visible_columns() {
    //console.log(table);
   var all_columns = table.settings().init().columns;
    console.log('all_columns', all_columns);
    var visible_columns = [];
    for (var i in all_columns) {
        if (table.column(all_columns[i].name + ':name').visible()) {
            visible_columns.push(all_columns[i].name);
            console.log("index: "+i);
        }
    }

    alert(visible_columns.join(', '));
}

Индекс будет использоваться для восстановления всех видимых столбцов

table.columns( [ 0, 1, 2, 3 ] ).visible( false, false );

Рабочая скрипка

1 голос
/ 17 июня 2019

Использование DataTable.columns().visible()

UPDATE

Использование columns().every( fn )

let dataTable = $('#example').DataTable({
  "colReorder": true,
  "columnDefs": [
    { "visible": false, "targets": [1] },
    { "visible": false, "targets": [4] },
    { "visible": false, "targets": [5] },
  ]
});

// let result = dataTable.columns().visible().reduce((a, v, i) => v ? [...a, i] : a, [])

// console.log(result)

dataTable.on('column-reorder', function() {
  console.clear();
  dataTable.columns().every(function(i) {
    this.visible() && console.log(i, this.header().innerHTML)
  });
});
<script src="https://cdnjs.cloudflare.com/ajax/libs/jquery/3.3.1/jquery.min.js"></script>
<script src="https://cdn.datatables.net/1.10.19/js/jquery.dataTables.min.js"></script>
<link href="https://cdn.datatables.net/1.10.19/css/jquery.dataTables.min.css" rel="stylesheet" />
<link href="https://cdn.datatables.net/colreorder/1.5.1/css/colReorder.dataTables.min.css" rel="stylesheet" />
<script src="https://cdn.datatables.net/colreorder/1.5.1/js/dataTables.colReorder.min.js"></script>


<table id="example" class="display" style="width:100%">
  <thead>
    <tr>
      <th>Name</th>
      <th>Position</th>
      <th>Office</th>
      <th>Numero</th>
      <th>Start date</th>
      <th>Salary</th>
    </tr>
  </thead>
  <tbody>
    <tr>
      <td>Tiger Nixon</td>
      <td>System Architect</td>
      <td>Edinburgh</td>
      <td>155555</td>
      <td>2011/04/25</td>
      <td>$320,800</td>
    </tr>
    <tr>
      <td>Garrett Winters</td>
      <td>Accountant</td>
      <td>Tokyo</td>
      <td>63</td>
      <td>2011/07/25</td>
      <td>$170,750</td>
    </tr>
    <tr>
      <td>Ashton Cox</td>
      <td>Junior Technical Author</td>
      <td>San Francisco</td>
      <td>1</td>
      <td>2009/01/12</td>
      <td>$86,000</td>
    </tr>
  </tbody>
</table>
...