• 首页
  • vue
  • TypeScript
  • JavaScript
  • scss
  • css3
  • html5
  • php
  • MySQL
  • redis
  • jQuery
  • 热重载

    使用webpackHot Module Replacement API,Vuex 支持在开发过程中热重载mutationmoduleaction getter。你也可以在 Browserify 中使用browserify-hmr插件。

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

    // store.js
    import { createStore } from 'vuex'
    import mutations from './mutations'
    import moduleA from './modules/a'
    
    const state = { ... }
    
    const store = createStore({
      state,
      mutations,
      modules: {
        a: moduleA
      }
    })
    
    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
        // 加载新模块
        store.hotUpdate({
          mutations: newMutations,
          modules: {
            a: newModuleA
          }
        })
      })
    }
    


    动态模块热重载

    require.context()webpack中,用来创建自己的(模块)上下文。webpack会在构建的时候,解析代码中的require.context()

    如果你仅使用模块,你可以使用require.context来动态地加载或热重载所有的模块。

    // store.js
    import { createStore } from 'vuex'
    
    // 加载所有模块。
    function loadModules() {
      const context = require.context("./modules", false, /([a-z_]+)\.js$/i)
    
      const modules = context
        .keys()
        .map((key) => ({ key, name: key.match(/([a-z_]+)\.js$/i)[1] }))
        .reduce(
          (modules, { key, name }) => ({
            ...modules,
            [name]: context(key).default
          }),
          {}
        )
    
      return { context, modules }
    }
    
    const { context, modules } = loadModules()
    
    const store = new createStore({
      modules
    })
    
    if (module.hot) {
      // 在任何模块发生改变时进行热重载。
      module.hot.accept(context.id, () => {
        const { modules } = loadModules()
    
        store.hotUpdate({
          modules
        })
      })
    }