代码块-常见业务场景

此文用于个人总结、收集日常工作中常见的业务代码,以此提高自身效率

场景reactdva


发送两个相互依赖的异步请求
  • dva中,采用的是基于redux-saga的异步解决方案,将异步请求全部收集到effects中进行统一处理。因此:
    • 我们可以在获取到一个yield call(fetchDataAsync, payload)的结果res后,以此respayload,继续put另一个异步action
    • 或者是干脆在后面直接跟yield call(fetchDataAsyncAnother, payload)
    • dispatch第一个异步action时,除了常见的typepayload外,我们还可以传入一个callback,在获取到请求的结果res后,使用yield调用该callback,并将res当作参数传入,在callback中,发起另一个异步action,如下:
// page.js
fetchData = () => {
    const { dispatch } = this.props
    dispatch({
      type: 'page/fetchData',
      payload: { pageNumber: 1, pageSize: 30 },
      cb: (list) => {
        // fetchAnotherData
      },
    })
}

// models/page.js
effects: {
    *fetchData({ payload }, { call, put }) {
        const res = yiela call(fetchFn, payload)
        const arr = Array.isArray(res.content) ? res.content : []
        yield put({
            type: 'changeStore',
            payload: {
                arr
            }
        })
        yield cb && cb(arr)
    },
}
复制代码

页面某些内容发生改变后重新发送异步请求获取数据
  • 随着React版本的更新,已经不推荐在componentWillReceiveProps里发送异步请求了。目前个人的编码中,如有类似的需求场景,已全部转移到componentDiaUpdate中重新发送异步请求

通过某个id组成的数组,在另一个总的对象数组里查找对应数据。常见于各种下拉框联动。

比如一个"项目"下拉选择器和一个“项目参与者”下拉选择器;在没有选择项目的时候,加载所有的参与者;而一旦选择了某个项目,则只显示对应的参与者。其实引申一下,就是一个数组求交、并集的问题

const projectListId = [1]
const memberList = [
    {projectId: 1, name: '小明', id: xxx},
    {projectId: 1, name: '小黑', id: xxx},
    {projectId: 2, name: '小黄', id: xxx},
    {projectId: 3, name: '小红', id: xxx},
    {projectId: 4, name: '小白', id: xxx}
]
const res = memberList.filter(member => projectListId.indexOf(member.projectId) > -1)
console.log(res) 
// [{projectId: 1, name: '小明', id: xxx}, {projectId: 1, name: '小黑', id: xxx}]
复制代码

转载于:https://juejin.im/post/5caca3e5e51d456e747c52fa

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值