모바일 환경에서 갤러리 페이지에서의 스크롤이 부자연스럽게 이뤄지는 버그 수정

This commit is contained in:
static
2026-01-02 17:04:08 +09:00
parent c0e71993e9
commit 5729af380d
2 changed files with 21 additions and 22 deletions

View File

@@ -34,15 +34,18 @@
if (!element) return; if (!element) return;
const observer = new ResizeObserver(() => { const observer = new ResizeObserver(() => {
scrollMargin = element!.getBoundingClientRect().top + window.scrollY; scrollMargin = Math.round(element!.getBoundingClientRect().top + window.scrollY);
}); });
observer.observe(element.parentElement!); observer.observe(element.parentElement!);
return () => observer.disconnect(); return () => observer.disconnect();
}); });
</script> </script>
<div bind:this={element} class={["relative", className]}> <div
<div style:height="{$virtualizer.getTotalSize()}px"> bind:this={element}
class={["relative", className]}
style:height="{$virtualizer.getTotalSize()}px"
>
{#each $virtualizer.getVirtualItems() as virtualItem (virtualItem.key)} {#each $virtualizer.getVirtualItems() as virtualItem (virtualItem.key)}
<div <div
class="absolute left-0 top-0 w-full" class="absolute left-0 top-0 w-full"
@@ -54,7 +57,7 @@
</div> </div>
{/each} {/each}
</div> </div>
{#if placeholder && $virtualizer.getVirtualItems().length === 0} {#if placeholder && $virtualizer.getVirtualItems().length === 0}
{@render placeholder()} {@render placeholder()}
{/if} {/if}
</div>

View File

@@ -49,11 +49,7 @@
<RowVirtualizer <RowVirtualizer
count={rows.length} count={rows.length}
itemHeight={(index) => itemHeight={(index) =>
rows[index]!.type === "header" rows[index]!.type === "header" ? 28 : 181 + (rows[index]!.isLast ? 16 : 4)}
? 28
: Math.ceil(rows[index]!.files.length / 4) * 181 +
(Math.ceil(rows[index]!.files.length / 4) - 1) * 4 +
16}
class="flex flex-grow flex-col" class="flex flex-grow flex-col"
> >
{#snippet item(index)} {#snippet item(index)}