A very simple, highly customisable react top progressbar component.
Install react-nprogress-latest with npm
npm i react-nprogress-latest
To use your library for routing change or as a top progress bar, follow these steps:
- For Route Change:
If you want to use your library for route changes, you should import it inside your
App.js
file.
import NProgress from "react-nprogress-latest";
import "react-nprogress-latest/dist/style.css";
function App() {
return <NProgress options={{ OnRouteChange: true }} />;
}
The delayMs
prop determines the delay in milliseconds before NProgress completes. This value influences the speed of progress completion when the component is triggered. A higher value for delayMs
results in a slower progression, while a lower value speeds up the completion.
<NProgress delayMs={800} options={{ OnRouteChange: true }} />
- As Top Progress Bar: To use your library as a top progress bar in any part of your application, you can import it anywhere in your code where you want it to appear.(Recommended->Header)
import NProgress from "react-nprogress-latest";
import "react-nprogress-latest/dist/style.css";
function App() {
return <NProgress options={{ onSectionScroll: true }} />;
}
The steps
prop determines the number of steps for progress completion when the component is triggered. The value of steps
should not exceed 9, as the calculation (steps * 0.1
) must not result in a value greater than 1, causing the NProgress to disappear.
<NProgress steps={8} options={{ onRouteChange: true }} />
Changes the minimum percentage used upon starting.
<NProgress configure={{ minimum: 0.1 }} />
You can change the markup using the template option. To keep the progress bar working, make sure to include an element with role='bar' in the [template].
<NProgress configure={{ template: "<div class='....'>...</div>" }} />
Adjust animation settings using the easing option (a CSS easing string) and the speed option (in milliseconds).If you are using the options prop, it is recommended not to use the speed option independently.
<NProgress configure={{ easing: "ease", speed: 500 }} />
Turn off the automatic incrementing behavior by setting the trickle option to false
. If you are using the options prop, it is recommended not to use the trickle option independently.
<NProgress configure({ trickle: false })/>
Adjust how often to trickle/increment, in milliseconds.If you are using the options prop, it is recommended not to use the trickleSpeed option independently.
<NProgress configure={{ trickleSpeed: 200 }} />
Turn off loading spinner by setting it to false.
<NProgress configure={{ showSpinner: false }} />
Specify this option to change the parent container.
<NProgress configure={{ parent: "#container" }} />