Accidentally pushing multiple new history items in quick succession is a common error in web apps. It breaks the history navigation and leads to frustrated users. History Throttler provides a simple fix for this issue.
Table of Contents
npm install history-throttler
History Throttler exposes an alternative to the native history.pushState
, that does the following.
-
It has the exact same arguments as history.pushState.
-
It calls
history.pushState
, if no new history item was added since the last repaint and the document is fully loaded. -
It calls
history.replaceState
otherwise.
As a result it never pushes more than one history item between two repaints, but it keeps the history fresh all the time.
import pushState from 'history-throttler'
// this adds a new history item
pushState({ historyProp: 'value' }, 'title', 'url')
// this replaces the above item, instead of adding a new
pushState({ historyProp: 'otherValue' }, 'title2', 'url/2')
Simply overwrite history.pushState
to fix unwanted double-history-entry issues in your app.
import pushState from 'history-throttler'
history.pushState = pushState
This only works if your routing solution uses the HTML5 History API, it does not work with older hashbang based solutions.
- Chrome: 23 and above
- Firefox: 24 and above
- Safari: 7 and above
- Opera: 15 and above
- Edge: 12 and above
- IE: 10 and above
This library detects if you use ES6 or commonJS modules and serve the right format to you. The exposed bundles are transpiled to ES5 to support common tools - like UglifyJS minifying. If you would like a finer control over the provided build, you can specify them in your imports.
history-throttler/dist/es.es6.js
exposes an ES6 build with ES6 modules.history-throttler/dist/es.es5.js
exposes an ES5 build with ES6 modules.history-throttler/dist/cjs.es6.js
exposes an ES6 build with commonJS modules.history-throttler/dist/cjs.es5.js
exposes an ES5 build with commonJS modules.
If you use a bundler, set up an alias for history-throttler
to point to your desired build. You can learn how to do it with webpack here and with rollup here.
Contributions are always welcome. Just send a PR against the master branch or open a new issue. Please make sure that the tests and the linter pass. Thanks!