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

Я пытаюсь создать HTML-таблицу с прокручиваемым телом, чтобы вы всегда могли видеть заголовок.Я хочу, чтобы таблица находилась внутри div и имела максимальную высоту 100% от высоты div.Элементы таблицы генерируются динамически, поэтому, если их слишком много, вы получите полосу прокрутки на теле.Но если элементов очень мало, я хочу, чтобы таблица сократилась и не использовала всю высоту div.

Я могу установить высоту таблицы на 100%, а также установить отображение для блока tbody и задать ему максимальную высоту 100%.Проблема в том, что даже если нет элементов, тело таблицы по-прежнему использует полную высоту для отображения пустой таблицы.

Я могу установить фиксированную максимальную высоту для tbody и установить высоту для таблицы наавто.Таким образом, таблица сокращается, когда есть несколько элементов вместо того, чтобы показывать пустое тело.Проблема в том, что высота больше не контролируется div.

html:

<div>
  <table>
    <thead>
      <tr>
        <th > col1</th>
        <th> col 2</th>
      </tr>
    </thead>
    <tbody>
    </tbody>
  </table>
</div>

css

tbody{
  display: block;
  max-height: 100%;
  overflow: auto;
  }

table{
  height: 100%;
  border: 1px solid black;

}

div{
  height: 300px;
}

1 Ответ

0 голосов
/ 28 июля 2019

Используйте DataTable для этой проблемы.Вот демо:

$(document).ready(function() {
  $('#example').DataTable({
    "scrollY": 100,
    "scrollX": true
  });
});
<script src="https://code.jquery.com/jquery-3.3.1.js"></script>
<script src="https://cdn.datatables.net/1.10.19/js/jquery.dataTables.min.js"></script>
<link rel="stylesheet" href="https://cdn.datatables.net/1.10.19/css/jquery.dataTables.min.css">
<table id="example" class="display nowrap" style="width:100%">
  <thead>
    <tr>
      <th>First name</th>
      <th>Last name</th>
      <th>Position</th>
      <th>Office</th>
      <th>Age</th>
      <th>Start date</th>
      <th>Salary</th>
      <th>Extn.</th>
      <th>E-mail</th>
    </tr>
  </thead>
  <tbody>
    <tr>
      <td>Tiger</td>
      <td>Nixon</td>
      <td>System Architect</td>
      <td>Edinburgh</td>
      <td>61</td>
      <td>2011/04/25</td>
      <td>$320,800</td>
      <td>5421</td>
      <td>t.nixon@datatables.net</td>
    </tr>
    <tr>
      <td>Garrett</td>
      <td>Winters</td>
      <td>Accountant</td>
      <td>Tokyo</td>
      <td>63</td>
      <td>2011/07/25</td>
      <td>$170,750</td>
      <td>8422</td>
      <td>g.winters@datatables.net</td>
    </tr>
    <tr>
      <td>Ashton</td>
      <td>Cox</td>
      <td>Junior Technical Author</td>
      <td>San Francisco</td>
      <td>66</td>
      <td>2009/01/12</td>
      <td>$86,000</td>
      <td>1562</td>
      <td>a.cox@datatables.net</td>
    </tr>
    <tr>
      <td>Cedric</td>
      <td>Kelly</td>
      <td>Senior Javascript Developer</td>
      <td>Edinburgh</td>
      <td>22</td>
      <td>2012/03/29</td>
      <td>$433,060</td>
      <td>6224</td>
      <td>c.kelly@datatables.net</td>
    </tr>
    <tr>
      <td>Airi</td>
      <td>Satou</td>
      <td>Accountant</td>
      <td>Tokyo</td>
      <td>33</td>
      <td>2008/11/28</td>
      <td>$162,700</td>
      <td>5407</td>
      <td>a.satou@datatables.net</td>
    </tr>
    <tr>
      <td>Ashton</td>
      <td>Cox</td>
      <td>Junior Technical Author</td>
      <td>San Francisco</td>
      <td>66</td>
      <td>2009/01/12</td>
      <td>$86,000</td>
      <td>1562</td>
      <td>a.cox@datatables.net</td>
    </tr>
    <tr>
      <td>Cedric</td>
      <td>Kelly</td>
      <td>Senior Javascript Developer</td>
      <td>Edinburgh</td>
      <td>22</td>
      <td>2012/03/29</td>
      <td>$433,060</td>
      <td>6224</td>
      <td>c.kelly@datatables.net</td>
    </tr>
    <tr>
      <td>Airi</td>
      <td>Satou</td>
      <td>Accountant</td>
      <td>Tokyo</td>
      <td>33</td>
      <td>2008/11/28</td>
      <td>$162,700</td>
      <td>5407</td>
      <td>a.satou@datatables.net</td>
    </tr>
  </tbody>
</table>

Вот подробности: https://datatables.net/examples/basic_init/scroll_xy.html

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...