Simple file-based routing for Vite. Currently only React Router is supported, and only dynamic page import is supported. Static import is not envisioned or planned.
- Only data routers support
- Lazy loading routes by
lazy
property - Support data
loaders
,actions
anderror-boundary
- Ignored routes per directory
- Typescript support
Install:
npm install -D vite-plugin-lazy-pages
npm install react-router react-router-dom
Integrate:
// vite.config.js
import lazyPages from 'vite-plugin-lazy-pages'
export default {
plugins: [
lazyPages(),
],
}
// main.js
import React from 'react'
import ReactDOM from 'react-dom/client'
import { RouterProvider, createBrowserRouter } from 'react-router-dom';
import routes from 'virtual:lazy-pages'
const router = createBrowserRouter(routes)
ReactDOM.createRoot(document.getElementById('root')).render(
<React.StrictMode>
<RouterProvider fallbackElement="router loading..." router={router} />
</React.StrictMode>,
)
Pass your options to lazyPages
function for customize:
// vite.config.js
import lazyPages from 'vite-plugin-lazy-pages'
export default {
plugins: [
lazyPages({
pages: [ { dir: 'src/pages', filePattern: /^.*\.(js|jsx|ts|tsx)$/ } ],
exportMode: 'default',
exclude [ 'src/pages/dev' ],
extendRoute (route) => {
route.handle.auth = true;
return route;
}
}),
],
}
- Type:
{ dir: string; filePattern: RegExp; }[]
- Default:
[ { dir: 'src/pages', filePattern: /^.*\.(js|jsx|ts|tsx)$/ } ]
Example structure:
src/
└── pages/
├── index.{jsx|tsx}
├── about.{jsx|tsx}
├── products/
│ ├── index.{jsx|tsx}
│ └── [id].{jsx|tsx}
└── names/
├── index.{jsx|tsx}
└── [name]
├── index.{jsx|tsx}
└── info.{jsx|tsx}
- Type:
'default' | 'named'
- Default:
'default'
Which component export you are using. default
is the default export of the component. named
- remix-like component export
- Type:
string[]
- Default:
[]
At this time, only directory exclusion is supported
- Type:
(route: RouteObject) => (RouteObject | Promise<RouteObject>)
- Default:
undefined
You can extend the route with this function. You can see an example above. Also the route is already an extended route. route.handle
is an object and contains a pattern
field.