dva 在umi中的使用

在react项目中,使用react+umi+dva+antd这一阿里系列技术栈的人越来越多,本文主要讲在umi中使用dva的过程

一、前言

在实际的前端开发中我们希望把数据逻辑和视图逻辑分开管理在不同的模块中,使得代码更加健壮,同时易于调试。
我们希望这些数据在需要的时候,可以提供给不同的组件使用:也即数据共享。

而 dva 就是用来满足这些需求的:

通过把状态上提到 dva model 中,我们把数据逻辑从页面中抽离出来。
通过 effect 优雅地处理数据生成过程中的副作用,副作用中最常见的就是异步逻辑。
dva model 中的数据可以注入给任意组件。
另外,dva 允许把数据逻辑再拆分(「页面」常常就是分隔的标志),以 namespace 区分。当你觉得有必要时,不同的 namespace 之间的 state 是可以互相访问的。

二 、主要对象介绍

dva 的 model 对象有几个基本的属性,需要掌握:

namespace:model 的命名空间,只能用字符串。一个大型应用可能包含多个 model,通过namespace区分。

state:当前 model 状态的初始值,表示当前状态。

reducers:用于处理同步操作,唯一可以修改 state的地方,由 action 触发。reducer 是一个纯函数,它接受当前的 state 及一个 action 对象。action 对象里面可以包含数据体(payload)作为入参,需要返回一个新的 state。

effects:用于处理异步操作(例如:与服务端交互)和业务逻辑,也是由 action 触发。但是,它不可以修改 state,要通过触发 action 调用 reducer 实现对 state 的间接操作。

action:是 reducers 及 effects 的触发器,一般是一个对象,形如{ type: ‘add’, payload: todo },通过 type 属性可以匹配到具体某个 reducer 或者 effect,payload 属性则是数据体,用于传送给 reducer 或 effect。

三、简单使用

  1. 在umi项目 src目录下新建 models 目录(规定全局名称必须models)
    如下,我这里新建了个system.js文件 (名称随便取)
image.png

代码如下:

export default {
    // models命名空间,需全局唯一
    namespace: 'system',           
    // models存储的数据store                  
    state: {
        dataList: 1
    },      
    // 更新store,用新数据合并state的旧数据                                
    reducers: {
        save(state, { payload }) {                    
            return { ...state, ...payload };
        }
    },
};

在组件中进行使用

import React from 'react';
import { connect } from 'dva'
 
const hello = (props) => {
  const btnFn = async () =>{

    // 通过dispatch 调用文件下的save 改变dva 下 system 的 state的状态值
    props.dispatch({
      type: 'system/save',              // type,命名空间/reducers方法名                       
      payload: {
        dataList: props.system.dataList+1 // payload,参数
      }                                          
    })
  }

  return (
    <div>
      <button  onClick={ btnFn }>点击</button>
      { props.system.dataList }
    </div >
  )
}
 
// 建立组件与dva的连接
export default connect(({ system }) => ({ system }))(hello);

这样直接使用就可以获取到dav system下存的state状态值了,并通过连接进行修改

我这里目前暂时没写其它使用,主要针对刚开始使用dva,对里面的state状态数据进行操控

四、关于connect

connect 方法返回的也是一个 React 组件,通常称为容器组件。因为它是原始 UI 组件的容器,即在外面包了一层 State。connect 方法传入的第一个参数是 mapStateToProps 函数,该函数需要返回一个对象,用于建立 State 到 Props 的映射关系。

简而言之,connect的作用是将组件和models结合在一起。将models中的state绑定到组件的props中。并提供一些额外的功能,譬如dispatch建立组件与dva的连接通道

connect的连接方式有很多种

import React from 'react';
import { connect } from 'dva';

const hello = (props) => {

  return (
    <div>
      
    </div >
  )
}
 
export default connect(({ system }) => ({ system }))(hello);
import React from 'react';
import { connect } from 'dva';

connect(({ system }) => ({ system }))
const hello = (props) => {
  console.log(props)

  return (
    <div>
      2
    </div >
  )
}
 
export default hello;

3.使用ts的情况下

import React from 'react';
import { connect } from 'dva';

@connect(({ system }) => ({ system }))
const hello = (props:any) => {
  console.log(props)

  return (
    <div>
      dva
    </div >
  )
}
 
export default hello;

其实还有很多种,后续再更新哈,这篇文章只针对基础的,后续还会写篇进阶的

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 219,539评论 6 508
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 93,594评论 3 396
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 165,871评论 0 356
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 58,963评论 1 295
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 67,984评论 6 393
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 51,763评论 1 307
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 40,468评论 3 420
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 39,357评论 0 276
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 45,850评论 1 317
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 38,002评论 3 338
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 40,144评论 1 351
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,823评论 5 346
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 41,483评论 3 331
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 32,026评论 0 22
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 33,150评论 1 272
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 48,415评论 3 373
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 45,092评论 2 355

推荐阅读更多精彩内容