Improved hash mode support and fixed some bugs. Cleaned up the code and improved the documentation.
This commit is contained in:
		| @@ -301,24 +301,35 @@ class Router { | |||||||
|  |  | ||||||
|         if (refresh) { |         if (refresh) { | ||||||
|             if (Router.hashMode) { |             if (Router.hashMode) { | ||||||
|                 //In hash mode the route can't start with / or #, we have to handle it here. |                 //In hash mode the route can't start with # | ||||||
|                 if (route.startsWith("/") || route.startsWith("#")) { |                 if (route.startsWith("#")) { | ||||||
|                     route = route.substr(1); |                     route = route.substring(1); | ||||||
|  |                 } | ||||||
|  |  | ||||||
|  |                 //If the route starts with a / set the hash to the route, otherwise append the route | ||||||
|  |                 if (route.startsWith("/")) { | ||||||
|  |                     window.location.hash = route.substring(1); | ||||||
|  |                 } else { | ||||||
|  |                     window.location.hash = window.location.hash.substring(0, window.location.hash.lastIndexOf("/") + 1) + route; | ||||||
|                 } |                 } | ||||||
|  |  | ||||||
|                 window.location.hash = route; |  | ||||||
|                 window.location.reload(); |                 window.location.reload(); | ||||||
|             } else { |             } else { | ||||||
|                 window.location.href = route; |                 window.location.href = route; | ||||||
|             } |             } | ||||||
|         } else { |         } else { | ||||||
|             if (Router.hashMode) { |             if (Router.hashMode) { | ||||||
|                 //In hash mode the route can't start with / or #, we have to handle it here. |                 //In hash mode the route can't start with # | ||||||
|                 if (route.startsWith("/") || route.startsWith("#")) { |                 if (route.startsWith("#")) { | ||||||
|                     route = route.substr(1); |                     route = route.substring(1); | ||||||
|                 } |                 } | ||||||
|  |  | ||||||
|                 window.location.hash = route; |                 //If the route starts with a / set the hash to the route, otherwise append the route | ||||||
|  |                 if (route.startsWith("/")) { | ||||||
|  |                     window.location.hash = route.substring(1); | ||||||
|  |                 } else { | ||||||
|  |                     window.location.hash = window.location.hash.substring(0, window.location.hash.lastIndexOf("/") + 1) + route; | ||||||
|  |                 } | ||||||
|             } else { |             } else { | ||||||
|                 window.history.pushState(route, route, route); |                 window.history.pushState(route, route, route); | ||||||
|             } |             } | ||||||
| @@ -371,6 +382,7 @@ class Router { | |||||||
|  |  | ||||||
|         //If hash mode is set and we have a hash location, get it and split it. |         //If hash mode is set and we have a hash location, get it and split it. | ||||||
|         if (Router.hashMode && window.location.hash && window.location.hash.length > 0) { |         if (Router.hashMode && window.location.hash && window.location.hash.length > 0) { | ||||||
|  |             //Skip the # symbol | ||||||
|             var path = window.location.hash.substring(1); |             var path = window.location.hash.substring(1); | ||||||
|  |  | ||||||
|             //If the path contains ? then remove the query. |             //If the path contains ? then remove the query. | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user