Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/Purii/react-use-scrollspy
Flexible React Hook to automatically update navigation based on scroll position
https://github.com/Purii/react-use-scrollspy
hooks hooks-api-react javascript react reactjs scrollspy
Last synced: 4 months ago
JSON representation
Flexible React Hook to automatically update navigation based on scroll position
- Host: GitHub
- URL: https://github.com/Purii/react-use-scrollspy
- Owner: Purii
- License: mit
- Created: 2018-11-18T12:33:58.000Z (over 6 years ago)
- Default Branch: main
- Last Pushed: 2023-02-27T04:57:11.000Z (almost 2 years ago)
- Last Synced: 2024-06-18T15:30:38.172Z (8 months ago)
- Topics: hooks, hooks-api-react, javascript, react, reactjs, scrollspy
- Language: TypeScript
- Homepage: https://purii.github.io/react-use-scrollspy/
- Size: 3.32 MB
- Stars: 320
- Watchers: 5
- Forks: 16
- Open Issues: 15
-
Metadata Files:
- Readme: README.md
- Changelog: CHANGELOG.md
- Funding: .github/FUNDING.yml
- License: LICENSE
Awesome Lists containing this project
- fucking-awesome-react-hooks - `useScrollSpy`
- awesome-react-hooks-cn - `useScrollSpy`
- awesome-react-hooks - `useScrollSpy`
- awesome-react-hooks - `useScrollSpy`
README
# react-use-scrollspy
[data:image/s3,"s3://crabby-images/a17e0/a17e01b1ac92be2d3f1caeee6413f3d6ce36dfea" alt="Build Status"](https://travis-ci.org/Purii/react-use-scrollspy)
[data:image/s3,"s3://crabby-images/b98c5/b98c52728b83708bb45812c8b18caa6cfb21b13e" alt="npm version"](https://www.npmjs.com/package/react-use-scrollspy)
[data:image/s3,"s3://crabby-images/bdf53/bdf5301ba19d241d272eb8881fce182eedc5682b" alt="npm"](https://www.npmjs.com/package/react-use-scrollspy)
[data:image/s3,"s3://crabby-images/cd905/cd905e0a2ca7bdcc1e24610cd29a025951ccf9ef" alt="GitHub license"](https://raw.githubusercontent.com/Purii/react-use-scrollspy/master/LICENSE)
[data:image/s3,"s3://crabby-images/5a2e8/5a2e8313c7338b36e5b41c557d1ba234fec22f4e" alt="Donate"](https://www.patreon.com/purii)data:image/s3,"s3://crabby-images/ff024/ff0244910072e7e117222ce6d9a7b1daacca90fb" alt="Example"
## Installation
`react-use-scrollspy` is a React `Hook` which requires React **16.8.0 or later.**
```sh
// yarn
yarn add react-use-scrollspy
// or npm
npm i react-use-scrollspy --S
```## Usage
```javascript
import useScrollSpy from 'react-use-scrollspy';
...
const activeSection = useScrollSpy({
sectionElementRefs: [], // Array of References to DOM elements
});
```| Parameter | Default | Type | Description |
| :----------------- | :------: | :-----: | ----------------------------------------------------------- |
| defaultValue | `0` | `int` | Default value that is returned (optional) |
| offsetPx | `0` | `int` | Set offset (optional) |
| sectionElementRefs | `[]` | `[Ref]` | Array of Refs to observe (e.g. via React `refs`) |
| scrollingElement | `window` | `Ref` | Target of the scrolling (e.g. via React `refs`)) (optional) |### with Refs
Use React `refs` for section elements like in the [provided example](/example).
```javascript
import React, { useRef } from 'react';
import useScrollSpy from 'react-use-scrollspy';const App = () => {
const sectionRefs = [
useRef(null),
useRef(null),
useRef(null),
];const activeSection = useScrollSpy({
sectionElementRefs: sectionRefs,
offsetPx: -80,
});return (
Section 1
Section 2
Section 3
Section 1
Section 2
Section 3
)
```