vue 导出大数据量excel 页面 loading 不生效

如图,表格里面有9W+数据。在执行导出的时候页面会出现卡住的假象,并且loading改成了true,但并没有加载动画。
在这里插入图片描述
开始这样写的,打印出的spinning 已经是ture ,但加载动画并没有执行。

    const exportExcelClick = () => {
      const Header = [...]; //表头
      const Val = [...]; //表数据
      sdata.spinning = true; // 加载中
      console.log( sdata.spinning," sdata.spinning");
      const data = sdata.tableData;
      const title = `核酸采样信息表`;
      exportExcel(Header, Val, data, title); // 导出excel
      sdata.spinning = false;   // 加载结束
    };

于是修改成了

    const exportExcelClick = () => {
      const Header = [...]; //表头
      const Val = [...]; //表数据
      sdata.spinning = true; // 加载中
      console.log( sdata.spinning," sdata.spinning");
      const data = sdata.tableData;
      const title = `核酸采样信息表`;
      setTimeout(() => {
         exportExcel(Header, Val, data, title); //导出excel
      }, 100);
      setTimeout(() => {
        sdata.spinning = false;   // 加载结束
      }, 100);
    };

我的理解是,整个方法体里是一个宏任务,但执行到settimeout的时候会,开启另外一个宏任务,此时这个方法体里就有3个宏任务,先执行了赋值,加载状态赋值,页面的loading就开始转起来。然后执行第二个宏任务,导出excel,完毕之后开始执行第三个宏任务,结束加载的赋值。
然后页面的加载动画就可以正常实现了。

  • 2
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 3
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值