解决vue中使用axios来进行文件下载 出现乱码的问题 pk为前缀 (附带解决方案)

我们可以看到浏览器中输出的内容是pk前缀的乱码

我们将其转换为 Blob 格式后 来进行下载 代码如下:

download(page.value).then(res => {
        console.log(res.data);
        const blob = new Blob([res.data], { type: 'application/octet-stream' });
        const url = URL.createObjectURL(blob);
        const a = document.createElement('a');
        a.href = url;
        a.download = 'example.docx';
        a.click();
        URL.revokeObjectURL(url);
    });

下载后word文档内容打开后会提示

点击继续打开后 内容为乱码 内容如下

导致这个错误的原因为 我们在提交请求时没有指定返回值的类型

解决方法:

export function download(data){
    return request({
        url:'/question/question/download-word',
        method:'get',
        params:{
            typeId:data.typeId,
            question:data.question,
            subId:data.subId,
        }
    })
}

将其修改为:

// 导出word文件
export function download(data){
    return request({
        url:'/question/question/download-word',
        method:'get',
        responseType: 'blob',
        params:{
            typeId:data.typeId,
            question:data.question,
            subId:data.subId,
        }
    })
}

我们指定了其响应格式为 blob 格式 完美解决了这个问题

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值