热重载

使用 webpack 的 Hot Module Replacement API,redux-sam 支持在开发过程中热重载 mutation、module和action。你也可以在 Browserify 中使用 browserify-hmr 插件。

对于 mutation 和模块,你需要使用 store.hotUpdate() 方法:

// store.js
import { createStore } from 'redux-sam';
import { Component } from 'react';
import createLogger from 'redux-sam/logger';
import mutations from './mutations';
import moduleA from './modules/a';

const state = { ... };

const { store, sam } = createStore({
  state,
  mutations,
  modules: {
    a: moduleA
  },
  plugins: [process.env.NODE_ENV !== 'production' && createLogger()]
}, Component);

if (module.hot) {
  // 使 action 和 mutation 成为可热重载模块
  module.hot.accept(['./mutations', './modules/a'], () => {
    // 获取更新后的模块
    // 因为 babel 6 的模块编译格式问题,这里需要加上 `.default`
    const newMutations = require('./mutations').default
    const newModuleA = require('./modules/a').default
    // 加载新模块
    sam.hotUpdate({
      mutations: newMutations,
      modules: {
        a: newModuleA
      }
    })
  })
}

参考热重载示例 counter-hot