Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/nihgwu/react-native-dva-starter
a React Native starter powered by dva and react-navigation
https://github.com/nihgwu/react-native-dva-starter
dva react-native react-navigation starter
Last synced: 1 day ago
JSON representation
a React Native starter powered by dva and react-navigation
- Host: GitHub
- URL: https://github.com/nihgwu/react-native-dva-starter
- Owner: nihgwu
- Created: 2017-03-16T05:59:57.000Z (almost 8 years ago)
- Default Branch: master
- Last Pushed: 2022-12-07T09:47:41.000Z (about 2 years ago)
- Last Synced: 2025-01-04T07:13:01.104Z (9 days ago)
- Topics: dva, react-native, react-navigation, starter
- Language: JavaScript
- Size: 1.41 MB
- Stars: 643
- Watchers: 33
- Forks: 149
- Open Issues: 27
-
Metadata Files:
- Readme: README.md
Awesome Lists containing this project
README
# react-native-dva-starter
A React Native starter powered by [dva](https://github.com/dvajs/dva) and [react-navigation](https://github.com/react-community/react-navigation)
## Start
```bash
npm install dva-native-cli -g
dvanative git app
cd app
react-native run-ios # or react-native run-android
```Great thanks to @xuan45 for his cli tool [dva-native-cli](https://github.com/xuan45/dva-native-cli), check that project for more information.
## Advance
The builtin router of **dva** (not **react-router v4**), doesn't support React Native, we have to integrate other router components, such as **Navigator**, **ExperimentalNavigation**, **react-native-router-flux** and **react-navigation**. Since the former two will be depreciated in flavor of **react-navigation**, which is also be recommended by official, so I choose it to be the navigator.
In this starter, I provide a router model to control the default action flow of **react-navigation** to workaround a known [issue](https://github.com/react-community/react-navigation/issues/271). If you don't need this, the integration will be much simpler, you can simply remove the router model and pass **routerReducer** to **extraReducer** of dva `extraReducers: { router: routerReducer }`. Read [Redux Integration](https://reactnavigation.org/docs/guides/redux) and [dva's API](https://github.com/dvajs/dva/blob/master/docs/API.md) for more information.Also there is another workaround for a missing feature https://github.com/react-community/react-navigation/issues/232, so I use two **StackNavigators** to contain the screens with different transition animations, you can create you own transition animations via **transitionConfig**, see https://github.com/react-community/react-navigation/pull/99
## LICENSE
MIT