vue项目中如何实现附件下载?

1.在main.js进行封装打开文件方法。

Vue.prototype.getServerUrl = function () {

  if (process.env.NODE_ENV === "development") {

    return "http://114.242.205.124:9000/";

  } else {

    return "";

  }

};

/**

 * 打开文件。获取文件ID,NAME保持与后端返回字段一致。

 */

Vue.prototype.openFile = function (fileBean) {

  if (fileBean && fileBean.FILE_ID) {

    if (fileBean.FILE_ID.toLowerCase().endsWith(".pdf")) {

      window.open(this.getServerUrl() + "/file/" + fileBean.FILE_ID + "?act=open");

    } else {

      let a = document.createElement("a");

      a.href = this.getServerUrl() + "/file/" + fileBean.FILE_ID;

      a.download = fileBean.FILE_NAME;

      document.body.appendChild(a);

      a.click();

      a.remove();

    }

  }

};

2.前端页面框架书写点击事件。

3.methods中进行书写方法。

 

4.即可实现下载效果。

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值