mirror of
https://github.com/kmc7468/arkvault.git
synced 2026-02-04 08:06:56 +00:00
모바일 환경에서 갤러리 페이지에서의 스크롤이 부자연스럽게 이뤄지는 버그 수정
This commit is contained in:
@@ -34,27 +34,30 @@
|
||||
if (!element) return;
|
||||
|
||||
const observer = new ResizeObserver(() => {
|
||||
scrollMargin = element!.getBoundingClientRect().top + window.scrollY;
|
||||
scrollMargin = Math.round(element!.getBoundingClientRect().top + window.scrollY);
|
||||
});
|
||||
observer.observe(element.parentElement!);
|
||||
return () => observer.disconnect();
|
||||
});
|
||||
</script>
|
||||
|
||||
<div bind:this={element} class={["relative", className]}>
|
||||
<div style:height="{$virtualizer.getTotalSize()}px">
|
||||
{#each $virtualizer.getVirtualItems() as virtualItem (virtualItem.key)}
|
||||
<div
|
||||
class="absolute left-0 top-0 w-full"
|
||||
style:transform="translateY({virtualItem.start - scrollMargin}px)"
|
||||
data-index={virtualItem.index}
|
||||
use:measureItem
|
||||
>
|
||||
{@render item(virtualItem.index)}
|
||||
</div>
|
||||
{/each}
|
||||
</div>
|
||||
{#if placeholder && $virtualizer.getVirtualItems().length === 0}
|
||||
{@render placeholder()}
|
||||
{/if}
|
||||
<div
|
||||
bind:this={element}
|
||||
class={["relative", className]}
|
||||
style:height="{$virtualizer.getTotalSize()}px"
|
||||
>
|
||||
{#each $virtualizer.getVirtualItems() as virtualItem (virtualItem.key)}
|
||||
<div
|
||||
class="absolute left-0 top-0 w-full"
|
||||
style:transform="translateY({virtualItem.start - scrollMargin}px)"
|
||||
data-index={virtualItem.index}
|
||||
use:measureItem
|
||||
>
|
||||
{@render item(virtualItem.index)}
|
||||
</div>
|
||||
{/each}
|
||||
</div>
|
||||
|
||||
{#if placeholder && $virtualizer.getVirtualItems().length === 0}
|
||||
{@render placeholder()}
|
||||
{/if}
|
||||
|
||||
@@ -49,11 +49,7 @@
|
||||
<RowVirtualizer
|
||||
count={rows.length}
|
||||
itemHeight={(index) =>
|
||||
rows[index]!.type === "header"
|
||||
? 28
|
||||
: Math.ceil(rows[index]!.files.length / 4) * 181 +
|
||||
(Math.ceil(rows[index]!.files.length / 4) - 1) * 4 +
|
||||
16}
|
||||
rows[index]!.type === "header" ? 28 : 181 + (rows[index]!.isLast ? 16 : 4)}
|
||||
class="flex flex-grow flex-col"
|
||||
>
|
||||
{#snippet item(index)}
|
||||
|
||||
Reference in New Issue
Block a user