сохраняйте статичность первого столбца (например, ранга) с помощью TableSorter, а также с помощью виджета 'Scroller' - PullRequest
0 голосов
/ 30 января 2019

Я пытаюсь сохранить статический первый столбец, используя плагин jQuery tablesorter - например, как ранжирование строк, которое всегда должно быть 1 к длине строки таблицы.Есть еще пара вопросов по поводу исправления столбца «rank», для которого ответчик написал небольшой плагин для сортировки таблиц, чтобы выполнить это.

Однако я также использую виджет «скроллер», чтобы первые два столбца оставались видимыми с широкой таблицей на мобильном телефоне.Когда также запущен скроллер, виджет indexFirstColumn, который написал ответчик, записывает пустую строку в верхней части таблицы, когда я нажимаю на заголовок таблицы, чтобы отсортировать таблицу, и общее количество строк увеличивается на единицу.

Заимствование виджета, написанного здесь:

Исключить столбец из сортировки с помощью jQuery tableorter

Тестирование здесь: https://jsbin.com/julavewole/edit?html,js,output

Как пример:

 <table class="tablesorter">
  <thead>
<tr>
  <th>Rank</th>
  <th>Name</th>
  <th>GP</th>
  <th>AB</th>
  <th>AVG</th>
  <th>2B</th>
  <th>3B</th>
  <th>HR</th>
  <th>RBI</th>
  <th>SLG</th>
  <th>OBP</th>
</tr>
  </thead>
  <tbody>
<tr>
  <td>1</td>
  <td>Bryce Harper</td>
  <td>123</td>
  <td>502</td>
  <td>.343</td>
  <td>23</td>
  <td>7</td>
  <td>41</td>
  <td>123</td>
  <td>.654</td>
  <td>.856</td>      
</tr>
<tr>
  <td>2</td>
  <td>J.D. Martinez</td>
  <td>113</td>
  <td>464</td>
  <td>.313</td>
  <td>45</td>
  <td>2</td>
  <td>46</td>
  <td>145</td>
  <td>.756</td>
  <td>1.012</td>
</tr>
<tr>
  <td>3</td>
  <td>Aaron Judge</td>
  <td>103</td>
  <td>392</td>
  <td>.293</td>
  <td>32</td>
  <td>12</td>
  <td>62</td>
  <td>89</td>
  <td>.453</td>
  <td>.822</td>
</tr>
<tr>
  <td>4</td>
  <td>Mike Trout</td>
  <td>114</td>
  <td>542</td>
  <td>.323</td>
  <td>43</td>
  <td>12</td>
  <td>37</td>
  <td>100</td>
  <td>.554</td>
  <td>.656</td>
</tr>
<tr>
  <td>5</td>
  <td>Mookie Betts</td>
  <td>112</td>
  <td>462</td>
  <td>.353</td>
  <td>37</td>
  <td>15</td>
  <td>29</td>
  <td>134</td>
  <td>.754</td>
  <td>.986</td>
</tr>
<tr>
  <td>6</td>
  <td>Ronald Acuna</td>
  <td>43</td>
  <td>178</td>
  <td>.243</td>
  <td>21</td>
  <td>8</td>
  <td>8</td>
  <td>89</td>
  <td>.454</td>
  <td>.556</td>
</tr>
<tr>
  <td>7</td>
  <td>Jose Altuve</td>
  <td>109</td>
  <td>472</td>
  <td>.303</td>
  <td>41</td>
  <td>2</td>
  <td>11</td>
  <td>67</td>
  <td>.534</td>
  <td>.576</td>
</tr>    
</tbody>
</table>

$ (function () {

  // add new widget called indexFirstColumn
  $.tablesorter.addWidget({
    // give the widget a id
    id: "indexFirstColumn",
    // format is called when the on init and when a sorting has finished
    format: function(table) {               
        // loop all tr elements and set the value for the first column  
        for(var i=0; i < table.tBodies[0].rows.length; i++) {
            $("tbody tr:eq(" + i + ") td:first",table).html(i+1);
        }                                   
    }
  });  
  $('table').tablesorter({
     sortList : [[4,1]],
     theme: 'default',
     widthFixed: false,
     sortInitialOrder: "desc",
     widgets: ['scroller',  'indexFirstColumn'],
     widgetOptions : {      
        scroller_height : 300,      
        scroller_upAfterSort: true,      
        scroller_jumpToHeader: true      
     }
  }); 
  $( 'table' ).trigger( 'setFixedColumnSize', 2 ); 
});
...