addListeners() adds the event listeners for client-side navigation —
a delegated click handler plus hashchange and popstate. It only
adds them once, so calling it repeatedly is safe and never duplicates
handlers. Call it during app setup before relying on
location or navigate.
Part of pota/use/location.
Call addListeners() once during app setup so in-app <a> clicks and
the browser back/forward buttons drive client-side navigation instead
of full page loads.
import { addListeners, location } from 'pota/use/location'
import { render } from 'pota'
addListeners()
function App() {
return (
<nav>
<a href="/about">about</a>
<a href="/contact">contact</a>
<p>current path: {location.pathname}</p>
</nav>
)
}
render(App)