Shyno
Don't be shy,no problem!

结构

 effects: {
    *pageQuery({ payload = {} }, { select, call, put }) {
      const res = yield call(pageQuery, payload);
      const list = yield select((s) => s.commodity.list);
      yield put({
        type: 'save',
        payload: {
          detail: res.result,
        },
      });
    },
}

 

 

 首先确认一点,effects里面的函数都是Generator函数.然后我们对里面的一些关键词进行分类来区分为啥effects里面的函数的函数要这么写.

 

yield

固定关键词,Generator函数自带的关键词,和"*"搭配使用.有点像async和await,使用"*"则表明它是Generator函数,然后每使用一个"yield"就是告诉程序这里是异步,需要等待这个后面的代码执行完成.同步代码可不使用该关键词

 

payload

view端通过dispatch传过来的payload同名参数

 

select, call, put

dva中effects函数的固定传参,他们分别对应不同的功能,用于不用场景

select

拿到model中state的数据

 const list = yield select((s) => s.commodity.list); 

 call

第一个参数是一个异步函数,payload是参数,可以通过call来执行一个完整的异步请求,又因为yield的存在,就实现了异步转同步的方案

const res = yield call(pageQuery, payload)

 put

可以使用同model中的reducers或者effects,通过reducers来实现数据到页面的更新.可以通过put实现effect的嵌套使用

 yield put({
        type: 'save',
        payload: {
          detail: res.result,
        },
      });

 

posted on 2021-12-14 18:22  Shyno  阅读(1842)  评论(0编辑  收藏  举报