From 907ae66568658f6d2603a90adfc70acc50a8c71b Mon Sep 17 00:00:00 2001 From: Kostia <74874576+Wordllban@users.noreply.github.com> Date: Mon, 28 Oct 2024 15:50:20 +0200 Subject: [PATCH] docs: extend scrollMargin description (#862) --- docs/api/virtualizer.md | 8 +++++++- 1 file changed, 7 insertions(+), 1 deletion(-) diff --git a/docs/api/virtualizer.md b/docs/api/virtualizer.md index bf407779..ffa51478 100644 --- a/docs/api/virtualizer.md +++ b/docs/api/virtualizer.md @@ -206,7 +206,13 @@ This optional function is called when the virtualizer needs to dynamically measu scrollMargin?: number ``` -With this option, you can specify where the scroll offset should originate. Typically, this value represents the space between the beginning of the scrolling element and the start of the list. This is especially useful in common scenarios such as when you have a header preceding a window virtualizer or when multiple virtualizers are utilized within a single scrolling element. +With this option, you can specify where the scroll offset should originate. Typically, this value represents the space between the beginning of the scrolling element and the start of the list. This is especially useful in common scenarios such as when you have a header preceding a window virtualizer or when multiple virtualizers are utilized within a single scrolling element. If you are using absolute positioning of elements, you should take into account the `scrollMargin` in your CSS transform: +```tsx +transform: `translateY(${ + virtualRow.start - rowVirtualizer.options.scrollMargin +}px)` +``` +To dynamically measure value for `scrollMargin` you can use `getBoundingClientRect()` or ResizeObserver. This is helpful in scenarios when items above your virtual list might change their height. ### `gap`