umi model 注册


model 分两类,一是全局 model,二是页面 model。全局 model 存于 /src/models/ 目录,所有页面都可引用;页面 model 不能被其他页面所引用。

规则如下:

  • src/models/**/*.js 为 global model
  • src/pages/**/models/**/*.js 为 page model
  • global model 全量载入,page model 在 production 时按需载入,在 development 时全量载入
  • page model 为 page js 所在路径下 models/**/*.js 的文件
  • page model 会向上查找,比如 page js 为 pages/a/b.js,他的 page model 为 pages/a/b/models/**/*.js + pages/a/models/**/*.js,依次类推
  • 约定 model.js 为单文件 model,解决只有一个 model 时不需要建 models 目录的问题,有 model.js 则不去找 models/**/*.js

举个例子,

+ src
  + models
    - g.js
  + pages
    + a
      + models
        - a.js
        - b.js
        + ss
          - s.js
      - page.js
    + c
      - model.js
      + d
        + models
          - d.js
        - page.js
      - page.js

如上目录:

  • global model 为 src/models/g.js
  • /a 的 page model 为 src/pages/a/models/{a,b,ss/s}.js
  • /c 的 page model 为 src/pages/c/model.js
  • /c/d 的 page model 为 src/pages/c/model.js, src/pages/c/d/models/d.js

#配置及插件

之前在 src/dva.js 下进行配置的方式已 deprecated,下个大版本会移除支持。

在 src 目录下新建 app.js,内容如下:

export const dva = { config: { onError(e) { e.preventDefault(); console.error(e.message); }, }, plugins: [ require('dva-logger')(), ], }; 

#FAQ

#url 变化了,但页面组件不刷新,是什么原因?

layouts/index.js 里如果用了 connect 传数据,需要用 umi/withRouter 高阶一下。

import withRouter from 'umi/withRouter'; export default withRouter(connect(mapStateToProps)(LayoutComponent)); 

#如何访问到 store 或 dispatch 方法?

window.g_app._store window.g_app._store.dispatch 

#如何禁用包括 component 和 models 的按需加载?

在 .umirc.js 里配置:

export default { plugins: [ [ 'umi-plugin-react', { dva: { dynamicImport: undefined // 配置在dva里 }, dynamicImport: undefined // 或者直接写在react插件的根配置,写在这里也会被继承到上面的dva配置里 } ], ], }; 

#全局 layout 使用 connect 后路由切换后没有刷新?

需用 withRouter 包一下导出的 react 组件,注意顺序。

import withRouter from 'umi/withRouter'; export default withRouter(connect()(Layout));


免责声明!

本站转载的文章为个人学习借鉴使用,本站对版权不负任何法律责任。如果侵犯了您的隐私权益,请联系本站邮箱yoyou2525@163.com删除。



 
粤ICP备18138465号  © 2018-2025 CODEPRJ.COM