https://github.com/w3c/csswg-drafts/issues/1009

дал пример скользящей сетки с фиксированными заголовками, используя технологии «CSS Grid Layout» и «Sticky Position». Для удобства содержимое сетки генерируется скриптом, который, я думаю, работает хорошо.

function fillGrid(selector, rows) {
  let cols = 3;
  let grid = $(selector);
  
  grid.empty();
  
  //cr header
  grid.append($('<div>').addClass('hcr').text('#'));
  
  //col headers
  for (let c = 1; c <= cols; c++) {
    grid.append($('<div>').addClass('hc').text(`Column ${c}`));
  }
  
  for (let r = 1; r <= rows; r++) {
    //row header
    grid.append($('<div>').addClass('hr').text(r));
    
    //cells
    for (let c = 1; c <= cols; c++) {
      grid.append($('<div>').addClass('c').text(`Cell ${r}-${c}`));
    }
  }
}

$('#reload').click(e => {
  var rows = Number.parseInt($('#rows').val());
  fillGrid('#grid1', rows);
})

$(document).ready(function() {
  fillGrid('#grid1', 10);
});
body {
  font-family: 'Segoe UI', sans-serif;
  font-size: 12px;
}

.grid {
  display: grid;
  width: 600px;
  height: 300px;
  grid-template-columns: 40px 200px 100px 500px;
  grid-auto-rows: min-content;
  border: 1px solid #ccc;
  overflow: scroll;
  margin-top: 20px;
  background-color: #aaa;
  margin-right: 10px;
}

.hcr, .hc, .hr {
  background-color: #ddd;
  border-right: 1px solid #ccc;
  border-bottom: 1px solid #ccc;
  padding: 2px;
  position: sticky;
}

.hcr {
  top: 0;
  left: 0;
  z-index: 1;
  text-align: center;
}

.hc {
  top: 0;
  white-space: nowrap;
}

.hr {
  left: 0;
  text-align: center;
}

.c {
  padding: 2px;
  border-right: 1px solid #ccc;
  border-bottom: 1px solid #ccc;
  background-color: #fff;
}
<script src="https://ajax.googleapis.com/ajax/libs/jquery/2.1.1/jquery.min.js"></script>
<div>
  <input type="text" id="rows" value="10" />
  <input type="button" id="reload" value="Reload" />
</div>
<div class="grid" id="grid1"></div>

До 999 рядов сетка работает отлично. Когда загружено более 999 строк, отображаются только ячейки до строки 999, а следующие ячейки неправильно расположены слева над заголовком строки 999.

Тот же пример работает правильно в Firefox 56 и Edge 16 (версия 16299).

Где я не прав?

Ответы на вопрос(1)

Решение Вопроса

предел 1000 строк (а также 1000 столбцов) был преднамеренно введен в движок Chrome из соображений стабильности и потребления ОЗУ. Новая версия функциональности Grid, кажется, находится в стадии разработки и должна решить проблему.

Источники:

https://bugs.chromium.org/p/chromium/issues/detail?id=688640https://github.com/w3c/csswg-drafts/issues/1009

Ваш ответ на вопрос