dva用法

该文章介绍了在Dva.js框架下,如何通过connect函数连接组件和状态,以及如何利用reducers和effects处理数据。具体展示了fetchData方法来获取表格数据,并通过request库调用API。同时,文章提到了如何设置命名空间和处理表单提交的状态。
摘要由CSDN通过智能技术生成

建立文件夹

 

引入

import { connect } from 'dva'

抛出修改

export default connect(state => {

    return {

        data: state.work.data//引入数据,work是你的models页面的名字,data是页面里面的数据

    }

})(Work)//页面名称,可自定义

function Work(props) {}

 解析

const { dispatch} = props

调用方法

dispatch({

            type: 'work/fetchData',//名字+方法

            payload: {//传递的参数

                page: 1,

                limit: 15,

            }

        })

index.js

import { history } from 'umi'; // 跳转方法

import request from '@/utils/request';//引入axios

import api from '@/services';


// 所有请求接口的数据都放到 dva

export default {

  // 命名空间跟文件夹名字一样

  namespace: 'work',



  state: {

    data: [], //表格数据

  },

  reducers: {

    setTable(state, { payload }) {

      const { list, count } = payload.data;

      return {

        ...state,

        data: list,//修改表格数据

        count, // 总条数

      };

    },

  },

  effects: {

    // 提交表单

    *fetchData({ payload }, { call, put, select }) {

      // payload: 参数

      const res = yield call(() =>

        request.get('/dev/adminapi/app/wechat/kefu', payload),

      );



      if (res.msg === 'ok') {

        yield put({//调用方法修改数据

          type: 'setTable',

          payload: res,

        });

      }

    },
     // 按钮
    *fetchStatus({ payload }, { call, put }) {
      const res = yield call(api.getSmapleStatus, payload);
      // console.log(res);
      if (res.status == 200) {
        return res.msg;
      }
    },

  },

};

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值