rn-dva

1.0.0 • Public • Published

react-native-dva

能在React Native环境使用的dva

简单使用

import dva from 'react-native-dva'
import dvaLoading from 'dva-loading'
import { 
  createReactNavigationReduxMiddleware
} from 'react-navigation-redux-helpers'
import { applyMiddleware } from 'redux';
 
import App from './App'
import { name as appName } from "./app.json";
 
import userModel from './modal/user'
import systemModel from './modal/system'
 
import nav from './reducer/nav'
 
const middleware = createReactNavigationReduxMiddleware(
  "root",
  state => state.nav,
);
 
const app = dva({
  extraEnhancers: [
    applyMiddleware(middleware)
  ],
  extraReducers: {
    nav
  },
  uses: [
    dvaLoading({ effects: true })
  ],
  models: [
    userModel,
    systemModel,
  ],
});
 
const MainApp = app.start(<App />);
AppRegistry.registerComponent(appName, () => MainApp);

加入redux-persist

import { persistStore, persistReducer } from 'redux-persist';
import { AsyncStorage } from 'react-native'
 
const createPersistStore = (rootReducer, createStore)=>{
  const persistConfig = {
    key: 'root',
    storage: AsyncStorage
  }
  const persistedReducer = persistReducer(persistConfig, rootReducer)
  return createStore(persistedReducer);
}
 
const StoreEnhancer  = () => (createStore)=> (rootReducer, prevState)=> createPersistStore(rootReducer, createStore);
 
//....
const app = dva({
  extraEnhancers: [
    StoreEnhancer(),
    applyMiddleware(middleware)
  ],
  //...
}
//...
const MainApp = app.start(<App />);
 
persistStore(app.getStore() , { storage : AsyncStorage }, (err, res)=>{
    console.log(err, res, app);
    const state = app._store.getState();
    const { system : { isFirst, doLogin }} = state;
    if(isFirst) {
      app._store.dispatch({
        type: 'system/resetPage',
        payload: 'Welcome'
      })
    } else if(doLogin) {
      // 未登录
      app._store.dispatch({
        type: 'system/resetPage',
        payload: 'UserLogin'
      })
    }
});

Versions

Current Tags

  • Version
    Downloads (Last 7 Days)
    • Tag
  • 1.0.0
    1
    • latest

Version History

  • Version
    Downloads (Last 7 Days)
    • Published
  • 1.0.0
    1

Package Sidebar

Install

npm i rn-dva

Weekly Downloads

1

Version

1.0.0

License

MIT

Unpacked Size

2.97 kB

Total Files

3

Last publish

Collaborators

  • liuhong1happy