dva-hot
TypeScript icon, indicating that this package has built-in type declarations

0.4.1 • Public • Published

dva-hot

version

HMR plugin for dva without babel inspired by babel-plugin-dva-hmr and react-hot-loader.

Install

$ npm install dva-hot

Usage

Patch App

import hot from 'dva-hot'
import dva from 'dva'
 
const app = dva()
 
hot.patch(app) // you must patch `app` before calling app.{model,router,start}
 
app.model(require('./models/a').default)
app.model(require('./models/b').default)
app.router(require('./router').default)
 
app.start('#root')

After dva@2.2.2, the usage below should work:

import hot from 'dva-hot'
import dva from 'dva'
import { createElement } from 'react'
import { render } from 'react-dom'
 
const app = dva()
 
hot.patch(app) // you can pass container to hot.patch like `hot.patch(app, container)`
 
app.model(require('./models/a').default)
app.model(require('./models/b').default)
app.router(require('./router').default)
 
// After dva@2.2.2: pass container for HMR
render(createElement(app.start()), hot.setContainer('#root'))
// or
// render(createElement(app.start()), hot.setContainer(document.querySelector('#root')))

Self-accepted Router

import React from 'react'
import { routerRedux } from 'dva/router'
import { renderRoutes } from 'react-router-config'
import hot from 'dva-hot'
import routes from '../routes'
 
const { ConnectedRouter } = routerRedux
 
function RouterConfig({ history }) {
  return <ConnectedRouter history={history}>{renderRoutes(routes)}</ConnectedRouter>
}
 
export default hot.router(module)(RouterConfig)

Self-accepted Model

import hot from 'dva-hot'
 
export default hot.model(module)({
  namespace: 'a-dva-model'
  state: [],
  // upgrade to dva@2.2.2 if you use models that without `reducers`
})

LICENSE

ISC

Readme

Keywords

Package Sidebar

Install

npm i dva-hot

Weekly Downloads

2

Version

0.4.1

License

ISC

Unpacked Size

11 kB

Total Files

7

Last publish

Collaborators

  • dgeibi