vue-use-scroll-size-observer
v1.0.4
Published
Vue3 composable that provides a simple and efficient way to observe changes to elements' `scrollWidth` and `scrollHeight` properties. It offers a similar API to `ResizeObserver`.
Downloads
96
Maintainers
Readme
useScrollSizeObserver
useScrollSizeObserver is a lightweight JavaScript library that provides a simple and efficient way to observe changes to elements' scrollWidth
and scrollHeight
properties. It offers a similar API to ResizeObserver
.
Features
- Easy Integration: Simple to integrate into existing projects with minimal setup.
- Efficient Observations: Utilizes modern browser APIs to efficiently track changes without impacting performance.
- Cross-Browser Compatibility: Compatible with major modern browsers, ensuring consistent behavior across different environments.
- TypeScript Support: Provides full support for TypeScript, enabling type-checking and enhanced development experience.
Installation
You can install ScrollSizeObserver via npm:
npm install vue-use-scroll-size-observer
Usage Vue 3 composable (example)
import { useScrollSizeObserver } from "vue-use-scroll-size-observer";
// Reactive!!!
const { previousScrollHeight, scrollHeight } = useScrollSizeObserver(bottomSheetCardContentRef);
watchPostEffect(() => {
if (!!props.autoRecalcHeight && !!scrollHeight.value && previousScrollHeight !== scrollHeight) {
// recalcHeight();
}
});
Usage ScrollSizeObserver
import { ScrollSizeObserver } from "vue-use-scroll-size-observer";
// Just like `ResizeObserver`
const observer = new ScrollSizeObserver((entries, observer) => {
entries.forEach((entry) => {
console.log('Target element:', entry.target)
console.log('New scrollWidth:', entry.scrollWidth)
console.log('New scrollHeight:', entry.scrollHeight)
console.log('Previous scrollWidth:', entry.previousScrollWidth)
console.log('Previous scrollHeight:', entry.previousScrollHeight)
})
})
// Observe an element
observer.observe(elementToObserve)
// Observe only `scrollHeight`
observer.observe(elementToObserve, { scrollWidth: false })
// Unobserve an element
observer.unobserve(elementToUnobserve)
// Unobserve all observed elements
observer.disconnect()
API
ScrollSizeObserver(callback: ScrollSizeObserverCallback)
Creates a new
ScrollSizeObserver
instance.callback
: A function called whenever an observed scroll size change occurs.
observe(target: Element, options?: ScrollSizeObserverOptions): void
Starts observing the specified
Element
.target
: A reference to theElement
to be observed.options
: An options object allowing you to set options for the observation.
unobserve(target: Element): void
Ends the observation of a specified
Element
.target
: A reference to theElement
to be unobserved.
disconnect(): void
Unobserves all observed
Element
targets.
License
This project is licensed under the MIT License - see the LICENSE file for details.
Contributing
Contributions are welcome! Fork the repository, make your changes, and submit a pull request. Thank you for helping improve our project!
Support
For any questions, issues, or feature requests, please open an issue.