Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/frontarm/navi
๐งญ Declarative, asynchronous routing for React.
https://github.com/frontarm/navi
navi react routing seo
Last synced: about 4 hours ago
JSON representation
๐งญ Declarative, asynchronous routing for React.
- Host: GitHub
- URL: https://github.com/frontarm/navi
- Owner: frontarm
- License: mit
- Created: 2016-09-24T07:44:26.000Z (about 8 years ago)
- Default Branch: master
- Last Pushed: 2024-07-01T10:24:49.000Z (5 months ago)
- Last Synced: 2024-12-08T15:37:19.601Z (5 days ago)
- Topics: navi, react, routing, seo
- Language: TypeScript
- Homepage: https://frontarm.com/navi/
- Size: 6.54 MB
- Stars: 2,065
- Watchers: 25
- Forks: 71
- Open Issues: 43
-
Metadata Files:
- Readme: README.md
- Changelog: CHANGELOG.md
- License: LICENSE-logo.md
Awesome Lists containing this project
- awesome-react-cn - navi - Declarative, asynchronous routing for React (Uncategorized / Uncategorized)
- awesome-react - navi - Declarative, asynchronous routing for React (Uncategorized / Uncategorized)
- awesome-react - navi - Declarative, asynchronous routing for React. ![](https://img.shields.io/github/stars/frontarm/navi.svg?style=social&label=Star) (Utilities / Router)
- awesome-learning-resources - navi - Declarative, asynchronous routing for React (Uncategorized / Uncategorized)
- awesome-list - navi
- awesome-react - navi - Declarative, asynchronous routing for React. ` ๐ a year ago` (React [๐](#readme))
- awesome-react-hooks - navi - ๐งญ Declarative, asynchronous routing for React. (Packages)
- awesome-react-cn - navi
- awesome - navi - ๐งญ Declarative, asynchronous routing for React. (TypeScript)
README
Navi (unmaintained)
Unmaintained declarative, asynchronous routing for React.**Navi is an *unmaintained* JavaScript library for declaratively mapping URLs to asynchronous content.**
It comes with:
- A set of modern React components and hooks, with Suspense support
- A static HTML generation tool that works with create-react-app *without* ejecting
- Great TypeScript support[View the docs ยป](https://frontarm.com/navi/)
Quick Start
-----------At it's core, Navi is just a router. You can use it with any React app โ just add the `navi` and `react-navi` packages to your project:
```bash
npm install --save navi react-navi
```If you'd like a more full featured starter, you can get started with [Create React/Navi App](https://frontarm.com/navi/create-react-navi-app/):
```bash
npx create-react-navi-app my-app
cd my-app
npm start
```Or if you want to create a blog, use [create-react-blog](https://github.com/frontarm/create-react-blog):
```bash
npx create-react-blog react-blog
cd react-blog
npm start
```Getting Started
---------------For a full introduction, see the [Getting Started](https://frontarm.com/navi/en/guides/getting-started/) guide on the Navi website.
Who's using Navi?
------------------ [Frontend Armory](http://frontarm.com)
- [Laska - a UI Builder for React Native](https://laska.io)
- [Otovo](https://www.otovo.com/) uses Navi for serving 80+ pages across three different markets ([.no](https://www.otovo.no), [.se](https://www.otovo.se) and [.fr](https://www.otovo.fr/))
- [Marek Calus' blog](https://mcalus.netlify.com/)
- [Offset Earth](https://offset.earth/)
- *Using Navi? Submit a Pull Request to add your site here!*Contributing
------------We are grateful to the community for contributing bugfixes, documentation, translations, and any other improvements.
This repository is monorepo that holds the source for Navi and it's related packages, while the Navi website -- which includes Navi's documentation, is part of the [navi-website](https://github.com/frontarm/navi-website) repository.
### Building and Testing Navi
To contribute code to Navi, you'll need to be able to build it and run the tests. To start, make sure you have [lerna](https://www.npmjs.com/package/lerna) 3.x installed globally:
```bash
npm install -g lerna
```Then fork, clone and bootstrap the repository:
```bash
lerna bootstrap
yarn build
yarn test
```If you're working on Navi itself, it's often easier to run builds and tests from `packages/navi`
```bash
cd packages/navi
yarn test:watch
```The [examples](./examples) are set up to use the copy of Navi at `packages/navi/dist`, so they can also be useful for quickly testing changes.
License
-------Navi is MIT licensed.