优化子组件在父组件中的方法回调

父组件中的子组件 传参和方法优化

<div>
   <SysDatasync :statisticsData="siteData" @refresh="handleRefresh('site')" />
   <SysDatasync :statisticsData="equiData" @refresh="handleRefresh('equi')" />
   <SysDatasync :statisticsData="warnData"  @refresh="handleRefresh('warn')" />
   <SysDatasync :statisticsData="userData"  @refresh="handleRefresh('user')" />
   <SysDatasync :statisticsData="orderData" refresh="handleRefresh('order')" />
</div>

方法:

import SysDatasync from '@/view/components/sys_datasync/index.vue'

export default {
  components: {
    SysDatasync
  },
  data() {
    return {
      siteData: {
        title: '草莓',
        action: '',
        totaldata: '',
        newdata: '',
        time: ''
      },
      equiData: {
        title: '桃子',
        action: '',
        totaldata: '',
        newdata: '',
        time: ''
      },
      warnData: {
        title: '葡萄',
        action: '',
        totaldata: '',
        newdata: '',
        time: ''
      },
      userData: {
        title: '芒果',
        action: '',
        totaldata: '',
        newdata: '',
        time: ''
      },
      orderData: {
        title: '西瓜',
        action: '',
        totaldata: '',
        newdata: '',
        time: ''
      }
    }
  },
  mounted() {
    this.fetchData(this.siteData, 2)
    this.fetchData(this.equiData, 3)
    this.fetchData(this.warnData, 5)
    this.fetchData(this.userData, 1)
    this.fetchData(this.orderData, 4)
  },
  methods: {
    //这里封装好后可省去重复的代码
    fetchData(dataObj, synctype) {
       //接口可能需要不同的参数synctype
       //拿到数据 data
          dataObj.totaldata = data.totaldata 
          dataObj.newdata =  data.newdata 
    },
    //同步后刷新页面
    handleRefresh(type) {
      switch (type) {
        case 'site':
          this.fetchData(this.siteData, 2)
          break
        case 'equi':
          this.fetchData(this.equiData, 3)
          break
        case 'warn':
          this.fetchData(this.warnData, 5)
          break
        case 'user':
          this.fetchData(this.userData, 1)
          break
        case 'order':
          this.fetchData(this.orderData, 4)
          break
      }
    }
  }
}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值