• 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));
  • 相关阅读:
    CentOS下Redis 2.2.14安装配置详解(转载)
    centos 6.3 64位安装php5.5及配置tengine
    linux下安装php扩展redis缓存
    linux安装ruby ruby-devel rubygems bundler
    composer的create-project安装php框架laravel for mac教程
    Homebrew安装php5及composer for mac教程
    KeepAlive详解
    方便mac os 10.9系统中phpstorm配置php运行环境
    Android使用adb工具及root权限完成手机抓包
    linux服务器监控流量sh脚本
  • 原文地址:https://www.cnblogs.com/thinkingthigh/p/11606539.html
Copyright © 2020-2023  润新知