java object blob,在Chrome中打开blob objectURL

在将blob url放入窗口之前必须打开新窗口:

let newWindow = window.open('/')

您还可以使用其他页面,如 /loading ,带有加载指示器 .

然后你需要等待newWindow加载,你可以在这个窗口中推送你的blob文件的url:

newWindow.onload = () => {

newWindow.location = URL.createObjectURL(blob);

};

Adblock扩展程序不会阻止它 .

我正在使用AJAX和ES生成器,如下所示:

let openPDF = openFile();

openPDF.next();

axios.get('/pdf', params).then(file => {

openPDF.next(file);

});

function* openFile() {

let newWindow = window.open('/pages/loading');

// get file after .next(file)

let file = yield;

// AJAX query can finish before window loaded,

// So we need to check document.readyState, else listen event

if (newWindow.document.readyState === 'complete') {

openFileHelper(newWindow, file);

} else {

newWindow.onload = () => {

openFileHelper(newWindow, file);

};

}

}

function openFileHelper(newWindow, file) {

let blob = new Blob([file._data], {type: `${file._data.type}`});

newWindow.location = URL.createObjectURL(blob);

}

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值