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