API Overview
This guide provides a quick overview of the lit-ui-router API. For detailed type signatures and complete documentation, see the API Reference.
Installation
bash
npm install lit-ui-router
# or
pnpm add lit-ui-routerQuick Start
ts
import { UIRouterLit, uiSref, uiSrefActive, LitStateDeclaration } from 'lit-ui-router';
import { hashLocationPlugin } from '@uirouter/core';
import { html } from 'lit';
// 1. Create router and add location plugin
const router = new UIRouterLit();
router.plugin(hashLocationPlugin);
// 2. Define states
const states: LitStateDeclaration[] = [
{ name: 'home', url: '/home', component: () => html`<h1>Home</h1>` },
{ name: 'users', url: '/users', component: UserListElement },
];
// 3. Register states and start
states.forEach((state) => router.stateRegistry.register(state));
router.urlService.rules.initial({ state: 'home' });
router.start();html
<!-- 4. Use in your app -->
<ui-router .uiRouter="${router}">
<nav>
<a ${uiSref('home')} ${uiSrefActive({ activeClasses: ['active'] })}>Home</a>
<a ${uiSref('users')} ${uiSrefActive({ activeClasses: ['active'] })}>Users</a>
</nav>
<ui-view></ui-view>
</ui-router>Core Concepts
Router
UIRouterLit is the main router class. It extends @uirouter/core's UIRouter with Lit-specific view handling.
Components
<ui-router>- Root component that provides router context to descendants<ui-view>- Viewport that renders the component for the current state
Directives
uiSref- Creates navigation links to statesuiSrefActive- Adds CSS classes when linked state is active
State Declaration
LitStateDeclaration defines a state with its URL and component:
ts
const state: LitStateDeclaration = {
name: 'users.detail',
url: '/:userId',
component: UserDetailElement,
resolve: [{ token: 'user', resolveFn: ($transition$) => fetchUser($transition$.params().userId) }],
};Lifecycle Hooks
Components can implement these interfaces to respond to routing events:
UiOnExit- Called before navigating away (can cancel navigation)UiOnParamsChanged- Called when route parameters change
Injected Props
Routed components receive UIViewInjectedProps with:
router- The UIRouter instancetransition- The current transitionresolves- Resolved data from state declarations
Location Plugins
Import from @uirouter/core:
ts
import { hashLocationPlugin, pushStateLocationPlugin } from '@uirouter/core';
// Hash URLs: /#/home
router.plugin(hashLocationPlugin);
// HTML5 pushState: /home
router.plugin(pushStateLocationPlugin);See the @uirouter/core location plugins documentation:
- PushStateLocationService - HTML5 history API
- HashLocationService - Hash-based URLs
Further Reading
- Tutorial - Step-by-step guide
- API Reference - Complete type documentation
- @uirouter/core docs - Core router documentation