keep router buffer on tab reload (#1393)
This commit is contained in:
parent
b2bc18c3d5
commit
2e2c6765b5
12
js/router.js
12
js/router.js
|
@ -3,13 +3,19 @@
|
|||
'use strict';
|
||||
|
||||
const router = {
|
||||
buffer: [],
|
||||
buffer: (history.state || {}).buffer || [],
|
||||
watchers: [],
|
||||
|
||||
getSearch(key) {
|
||||
return new URLSearchParams(location.search).get(key);
|
||||
},
|
||||
|
||||
push(url) {
|
||||
const state = history.state || {};
|
||||
state.buffer = router.buffer;
|
||||
history.pushState(state, null, url);
|
||||
},
|
||||
|
||||
update(replace) {
|
||||
const {buffer} = router;
|
||||
if (!buffer.length) {
|
||||
|
@ -53,7 +59,7 @@ const router = {
|
|||
if (!hash) {
|
||||
hash = ' ';
|
||||
}
|
||||
history.pushState(history.state, null, hash);
|
||||
router.push(hash);
|
||||
router.update();
|
||||
},
|
||||
|
||||
|
@ -83,7 +89,7 @@ window.on('popstate', () => router.update());
|
|||
window.on('hashchange', () => router.update());
|
||||
msg.on(e => {
|
||||
if (e.method === 'pushState' && e.url !== location.href) {
|
||||
history.pushState(history.state, null, e.url);
|
||||
router.push(e.url);
|
||||
router.update();
|
||||
return true;
|
||||
}
|
||||
|
|
Loading…
Reference in New Issue
Block a user