Dva快速入门,5分钟入门10分钟精通

dva 是一个基于 redux 和 redux-saga 的数据流方案,为了简化开发体验,dva 还额外内置了 react-router 和 fetch,所以也可以理解为一个轻量级的应用框架。

目前最流行的社区 React 应用架构方案如下

1.路由:React-Router

2.架构:Redux

3.异步操作:Redux-saga

缺点:要引入多个库,项目结构复杂。

dva 是将上面三个 React 工具库包装在一起,简化了 API,让开发 React 应用更加方便和快捷。

dva = React-Router + Redux + Redux-saga


一.Dva解决了React 没有解决的问题

React 本身只是一个 DOM 的抽象层,使用组件构建虚拟 DOM。

如果开发大应用,还需要解决2个问题。

·通信:组件之间如何通信

·数据流:数据如何和视图如何串联起来?路由和数据如何绑定?

1.通信问题

组件会发生三种通信

(1)向子组件发消息

(2)向父组件发消息

(3)向其他组件发消息

React 只提供了一种通信手段:传参。对于大应用来说很不方便。

react组件传参示例

react本身的传参是子组件通过父组件传入的函数,将自己的值再传回父组件。

2.数据流向:


数据的改变发生通常是通过用户交互行为或者浏览器行为(如路由跳转等)触发的,当此类行为会改变数据的时候可以通过 dispatch 发起一个 action,如果是同步行为会直接通过 Reducers 改变 State ,如果是异步行为会先触发 Effects 然后流向 Reducers 最终改变 State。

二.dva仅有6个api,对redux用户尤其友好

// 1.创建应用

const app = dva();

// 2.注册插件

app.use(createLoading());

// 3.注册model

app.model(model);

// 4.取消model注册,清理reducers,effects和subscriptions

app.unmodel(namespace)

// 5.注册路由

app.router(()=> );

// 6.启动应用

app.start('#root');

在这6步当中,dva完成了使用React解决view层、redux管理model、saga解决异步的主要功能。

三.Model

Model 是 dva 最重要的部分,所有的应用逻辑都定义在它上面,可以理解为 redux、react-redux、redux-saga 的封装。通常项目中一个模块对应一个 model。

model对象的例子

Model对象的属性:

1.namespace

是该 Model 的命名空间,只能用字符串,不支持通过 . 的方式创建多层命名空间。

2.state:

该 Model 当前的数据状态,直接决定了视图层的输出。

3.reducers:

Action处理器,处理同步操作,可以看做是state的计算器,类似于redux中的reducer,用来算出最新的state,是唯一可以修改state的地方,由action触发,它有state和action两个参数。

4.effects

Action处理器,处理异步动作,基于Redux-saga实现。

内部使用 yield 关键字,标识每一步的操作(不管是异步或同步)。

不能直接修改state,由action触发,也可触发action。

有action和effects两个参数,effects包含put、call和select三个字段,put用于触发action,类似于dispatch,call用于调用异步处理逻辑,select用于从state中获取数据。

5.subscriptions

用于订阅一个数据源,然后根据需要 dispatch 相应的 action。

相当于一个监听器,可以监听路由变化,鼠标,键盘变化,服务器连接变化,状态变化等,这样就可以根据不同变化做相应的处理,在这个subsription中的方法名是随意定的,每次变化都会去调用里面的所有方法,所以需要加相应的判断。

subscriptions: {

  setup({dispatch,history }){ 

    window.onresize =()=> {   

        //当浏览器的页面的大小变化时触发里面的dispatch方法

         dispatch(type:  "save")

    }

  },

  onClick({dispatch }){

    document.addEventListener('click',()=> {

        //当鼠标点击时触发里面的dispatch方法

         dispatch(type: "save")

    })

  }

}

四.connect方法

写完model和组件后,需要将model和组件连接起来。dva提供了connect方法,connect是一个函数,绑定State到View。connect后的组件可以获取到dispatch和state。

import { connect } from "dva"; 

class Counter extends Component {

    constructor(props){

        super(props)

    } 

    render(){

        return <div>{this.props.example.initText}</div>

    }

}

const mapStateToProps =(state)=>{

    //这里的example表示后面用this.props.example获取state(根节点)中exmpale命名空间中的state所有的数据

    return {

        example:state.example,

    }

}

//把model层的数据传递到当前组件

export default connect(mapStateToProps)(Counter) 

五.dispatch方法

dispatch是一个函数方法,用来将Action发送到Model。

dispatch({

  type: 'click-submit-button',

  payload: this.form.data

})

被connect的Component会自动在props中拥有dispatch方法。

六.异步请求

dva集成了isomorphic-fetch用于处理异步请求,并且使用dva-cli初始化的项目中,已经在./src/utils/request.js中对fetch进行了简单的封装,可以在这里根据服务端API的数据结构进行统一的错误处理。

最后千万注意:effects和reducers中的方法不能同名,否则会产生死循环

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