import { browser } from "@hickory/browser";
let history = browser(responseHandler, options);
When creating a history object, it must be passed a response handler function. This function will be called every time that a location change occurs. Any route matching/data loading that you need to perform should be triggered by this function.
The response handler function will be passed a "pending navigation" object. This object has four properties: location
, action
, finish
, and cancel
.
location
- This is the location object that is being navigated to.action
- This is the string (pop
,push
, orreplace
) for the navigation type.finish
- Once all matching/loading has finished, then you need to call thefinish
method to finalize the navigation. If you do not call this, the navigation will not actually occur.cancel
- This method allows you to cancel a navigation. It should be called if another location change occurs while the current pending navigation is still pending. Callingcancel
gives your history instance the opportunity to roll back to its previous state. This is only really necessary forpop
navigation since the browser has already changed the location before Hickory knows about the location change. This method takes one argument, an action string; the action string may be used to alter the cancel behavior.
-
query
- An object with two required properties:parse
andstringify
.-
parse
- A function that will convert a search string to a query value. This function should return a default value when it is called with no arguments. -
stringify
- A function that will convert a query value into a search string. This function should return an empty string when it is called with no arguments.
-
-
base
- An object withadd
andremove
functions for adding and removing a base segment from locations/URLs, which is useful if the application isn't hosted from the root directory of a domain. The object can be created using thecreateBase
function.
The current location object.
history.navigate({
url: "/oklahoma",
state: { musical: true }
});
The navigate
function is used to navigate to a new location.
There are three ways that it can do this: push
, replace
, and anchor
.
push
navigation pushes the new location onto the session history after the current location. Any existing locations after the current location are dropped.
history.navigate({ url: "/lion-king" }, "push");
replace
navigation replaces the current location with the new location. Any existing locations after the current location are unaffected.
history.navigate({ url: "/cats" }, "replace");
anchor
mimics the behavior of clicking on an<a>
element. When the new location's URL is exactly the same as the current location's, it will act likereplace
; when they are different, it will act likepush
.
history.navigate({ url: "/hairspray" }, "anchor");
to
- An object with a url
property, which is the URL to navigate to. The object can also include a state
property, which is state that should be attached to the location.
navType
- anchor
, push
, or replace
. If none are provided, this will default to anchor
.
history.go(-1);
history.go();
history.go(2);
The go
function is used to jump forward and backward to already visited locations. If you call it with a negative number, it goes backward. With a positive number, it goes forward. If you call it with no value (or 0
), it will reload the current location.
num
- The number of steps forward or backward to go.
history.url({ pathname: "/spamalot" });
// /spamalot
let base = createBase("/hip/hip");
let hiptory = browser(fn, { base });
hiptory.url("/hooray");
// /hip/hip/hooray
The url
function returns a URL string. It can take either a location object or a string.
If the history
is configured with a base segment, the base segment will be prepended to the URL string.
When the argument is an object:
- If the
pathname
isundefined
, the returned string will have no pathname component, including no base segment. - If the
pathname
is included, it is expected to be absolute (begin with a forward slash/
).
When the argument is a string:
- If the first character is a question mark (
?
) or hash symbol (#
), the returned string will have no pathname component, including no base segment. - When there is a pathname, it is expected to be absolute (begin with a forward slash).
location
- A location object or a string.
history.destroy();
The destroy
function allows you to remove all event listeners. Generally speaking, you will not need to call this. However, if for some reason you want to create a new history object, you should call this one on the existing history object .