nprogress vs react-top-loading-bar
Loading Indicators for Web Applications Comparison
1 Year
nprogressreact-top-loading-barSimilar Packages:
What's Loading Indicators for Web Applications?

Loading indicators are essential for enhancing user experience in web applications by providing visual feedback during asynchronous operations. They inform users that a process is ongoing, reducing uncertainty and improving perceived performance. Both 'nprogress' and 'react-top-loading-bar' serve this purpose, but they cater to different frameworks and use cases. 'nprogress' is a lightweight, standalone library that can be integrated into any web application, while 'react-top-loading-bar' is specifically designed for React applications, offering a more seamless integration with React's component lifecycle and state management.

Package Weekly Downloads Trend
Github Stars Ranking
Stat Detail
Package
Downloads
Stars
Size
Issues
Publish
License
nprogress1,467,43026,282-13510 years agoMIT
react-top-loading-bar56,65172470.3 kB64 months agoMIT
Feature Comparison: nprogress vs react-top-loading-bar

Integration

  • nprogress:

    Nprogress is a standalone library that can be integrated into any web application, regardless of the framework or library used. It requires minimal setup and can be easily added to existing projects with just a few lines of code, making it highly versatile for various environments.

  • react-top-loading-bar:

    React-top-loading-bar is specifically designed for React applications, leveraging React's component model. It provides a more natural integration with React's state management and lifecycle methods, allowing for easier control and customization of loading states.

Customization

  • nprogress:

    Nprogress offers basic customization options, such as changing the color and height of the loading bar through CSS. However, it may require additional effort to achieve more complex customizations, as it is not built with a component-based architecture in mind.

  • react-top-loading-bar:

    React-top-loading-bar provides a set of props that allow for extensive customization directly within the React component. Developers can easily modify the loading bar's appearance and behavior, including color, height, and progress control, making it more flexible for React projects.

Performance

  • nprogress:

    Nprogress is lightweight and designed for minimal impact on performance. It efficiently displays loading progress without introducing significant overhead, making it suitable for applications that prioritize speed and responsiveness.

  • react-top-loading-bar:

    React-top-loading-bar is optimized for React applications, ensuring that it does not cause unnecessary re-renders or performance bottlenecks. It integrates well with React's rendering process, maintaining high performance even in complex applications.

User Experience

  • nprogress:

    Nprogress enhances user experience by providing a clear visual indication of loading progress. Its simple design and smooth animations help users understand that their actions are being processed, reducing frustration during wait times.

  • react-top-loading-bar:

    React-top-loading-bar improves user experience in React applications by offering a customizable loading indicator that can be easily integrated into the app's workflow. It allows developers to provide feedback during data fetching or navigation, enhancing the overall user experience.

Community and Support

  • nprogress:

    Nprogress has a solid community and is widely used across various web applications. Its simplicity and effectiveness have led to a wealth of resources, tutorials, and community support, making it easy to find help when needed.

  • react-top-loading-bar:

    React-top-loading-bar is also well-supported within the React community, with documentation and examples readily available. Its design aligns with React best practices, making it a reliable choice for React developers seeking community-driven solutions.

How to Choose: nprogress vs react-top-loading-bar
  • nprogress:

    Choose 'nprogress' if you need a lightweight, framework-agnostic loading indicator that can be easily integrated into any web application, regardless of the technology stack. It is ideal for projects that do not use React or require a simple solution without additional dependencies.

  • react-top-loading-bar:

    Choose 'react-top-loading-bar' if you are building a React application and want a loading indicator that integrates smoothly with React's component lifecycle. It provides a more idiomatic approach to managing loading states in React, making it easier to control and customize.

README for nprogress

NProgress

Slim progress bars for Ajax'y applications. Inspired by Google, YouTube, and Medium.

Installation

Add nprogress.js and nprogress.css to your project.

<script src='nprogress.js'></script>
<link rel='stylesheet' href='nprogress.css'/>

NProgress is available via bower and npm and spm.

$ bower install --save nprogress
$ npm install --save nprogress

Basic usage

Simply call start() and done() to control the progress bar.

NProgress.start();
NProgress.done();

Using Turbolinks or similar? Ensure you're using Turbolinks 1.3.0+, and use this: (explained here)

$(document).on('page:fetch',   function() { NProgress.start(); });
$(document).on('page:change',  function() { NProgress.done(); });
$(document).on('page:restore', function() { NProgress.remove(); });

Ideas

  • Add progress to your Ajax calls! Bind it to the jQuery ajaxStart and ajaxStop events.

  • Make a fancy loading bar even without Turbolinks/Pjax! Bind it to $(document).ready and $(window).load.

Advanced usage

Percentages: To set a progress percentage, call .set(n), where n is a number between 0..1.

NProgress.set(0.0);     // Sorta same as .start()
NProgress.set(0.4);
NProgress.set(1.0);     // Sorta same as .done()

Incrementing: To increment the progress bar, just use .inc(). This increments it with a random amount. This will never get to 100%: use it for every image load (or similar).

NProgress.inc();

If you want to increment by a specific value, you can pass that as a parameter:

NProgress.inc(0.2);    // This will get the current status value and adds 0.2 until status is 0.994

Force-done: By passing true to done(), it will show the progress bar even if it's not being shown. (The default behavior is that .done() will not do anything if .start() isn't called)

NProgress.done(true);

Get the status value: To get the status value, use .status

Configuration

minimum

Changes the minimum percentage used upon starting. (default: 0.08)

NProgress.configure({ minimum: 0.1 });

template

You can change the markup using template. To keep the progress bar working, keep an element with role='bar' in there. See the default template for reference.

NProgress.configure({
  template: "<div class='....'>...</div>"
});

easing and speed

Adjust animation settings using easing (a CSS easing string) and speed (in ms). (default: ease and 200)

NProgress.configure({ easing: 'ease', speed: 500 });

trickle

Turn off the automatic incrementing behavior by setting this to false. (default: true)

NProgress.configure({ trickle: false });

trickleRate and trickleSpeed

You can adjust the trickleRate (how much to increase per trickle) and trickleSpeed (how often to trickle, in ms).

NProgress.configure({ trickleRate: 0.02, trickleSpeed: 800 });

showSpinner

Turn off loading spinner by setting it to false. (default: true)

NProgress.configure({ showSpinner: false });

parent

specify this to change the parent container. (default: body)

NProgress.configure({ parent: '#container' });

Customization

Just edit nprogress.css to your liking. Tip: you probably only want to find and replace occurrences of #29d.

The included CSS file is pretty minimal... in fact, feel free to scrap it and make your own!

Resources

Support

Bugs and requests: submit them through the project's issues tracker.
Issues

Questions: ask them at StackOverflow with the tag nprogress.
StackOverflow

Chat: join us at gitter.im.
![Chat](http://img.shields.io/badge/gitter-rstacruz / nprogress-brightgreen.svg)

Thanks

NProgress © 2013-2014, Rico Sta. Cruz. Released under the MIT License.
Authored and maintained by Rico Sta. Cruz with help from contributors.

ricostacruz.com  ·  GitHub @rstacruz  ·  Twitter @rstacruz

Status npm version spm package