LAFINSIR 2022-12-30 18:42 采纳率: 69.2%
浏览 26
已结题

vue2 处理多个类似的函数,但是函数中的变量名不一样,怎么优化

vue2 中有多个相同的方法,但是处理的数据不一样,怎么优化

img

比如有drawRoom,drawDesk,drawOffice类似的方法,只是处理的数据不一样,怎么通过参数来处理不同的情况

比如参数type是desk,我就处理this.deskData,type是room,我就处理this.roomData,即需要一个转义的写法,我就不用重复写类似的方法了。

  • 写回答

2条回答 默认 最新

  • |__WhoAmI__| 2022-12-30 19:37
    关注

    可以使用一个通用的方法,然后根据参数来决定使用哪个数据进行处理。例如:

    draw(type, filterData, hasData = true) {
      if (!hasData) {
        return;
      }
    
      let data;
      switch (type) {
        case 'desk':
          data = this.deskData;
          break;
        case 'room':
          data = this.roomData;
          break;
        case 'office':
          data = this.officeData;
          break;
      }
    
      let that = this;
      if (filterData && filterData.length > 0) {
        filterData.forEach((si, sk) => {
          data.forEach((item, k) => {
            // 处理数据
          });
        });
      } else {
        // 其他情况的处理
      }
    }
    

    然后在调用这个方法的时候,传入不同的参数即可。例如:

    this.draw('desk', filterData);
    

    或者

    this.draw('office', filterData);
    

    望采纳。

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
    1人已打赏
查看更多回答(1条)

报告相同问题?

问题事件

  • 系统已结题 1月7日
  • 已采纳回答 12月30日
  • 创建了问题 12月30日

悬赏问题

  • ¥15 微信公众平台自制会员卡可以通过收款码收款码收款进行自动积分吗
  • ¥15 随身WiFi网络灯亮但是没有网络,如何解决?
  • ¥15 gdf格式的脑电数据如何处理matlab
  • ¥20 重新写的代码替换了之后运行hbuliderx就这样了
  • ¥100 监控抖音用户作品更新可以微信公众号提醒
  • ¥15 UE5 如何可以不渲染HDRIBackdrop背景
  • ¥70 2048小游戏毕设项目
  • ¥20 mysql架构,按照姓名分表
  • ¥15 MATLAB实现区间[a,b]上的Gauss-Legendre积分
  • ¥15 delphi webbrowser组件网页下拉菜单自动选择问题