Skip to content

Commit

Permalink
feat: performance improvements for large lists
Browse files Browse the repository at this point in the history
  • Loading branch information
vcheckzen committed Oct 30, 2024
1 parent bb95afa commit b20f1fd
Showing 1 changed file with 9 additions and 8 deletions.
17 changes: 9 additions & 8 deletions front-end/index.html
Original file line number Diff line number Diff line change
Expand Up @@ -951,7 +951,7 @@
if (
pageRef.skipToken /* conflicts with loading next page */ ||
stat.renderedItems >= stat.children.length ||
Date.now() - stat.lastRenderedTs <= 800 /* 0.8s */
Date.now() - stat.lastRenderedTs <= 500 /* 0.5s */
) {
return;
}
Expand All @@ -970,7 +970,7 @@
renderItems();

function renderItems() {
const lastRenderedIndex = stat.renderedItems - 1;
const startIndex = stat.renderedItems;

stat.lastRenderedTs = Date.now();
stat.renderedItems += stat.batchSize;
Expand All @@ -981,15 +981,16 @@
const fragment = document.createDocumentFragment();
fragment.append(
...stat.children
.slice(0, stat.renderedItems)
.slice(startIndex, stat.renderedItems)
.map((create) => create())
);
listContainer.replaceChildren(fragment);
if (stat.renderedItems !== stat.batchSize) {
listContainer.querySelectorAll('.row')[
lastRenderedIndex
].style.backgroundColor = '#f1f1f1';
if (startIndex === 0) {
listContainer.replaceChildren(fragment);
} else {
stat.observer.disconnect();
listContainer.removeChild(listContainer.lastElementChild); // Marker
listContainer.lastElementChild.style.backgroundColor = '#f1f1f1';
listContainer.appendChild(fragment);
}
if (stat.renderedItems < stat.children.length) {
const loadingMarker = document.createElement('div');
Expand Down

0 comments on commit b20f1fd

Please sign in to comment.