在定义嵌套对象 属性 之前承诺解析
Promise resolving before nested object property is defined
我正在尝试 return 一个具有两个属性的对象...其中一个正在生成 blob,需要时间来解析。然而 javascript 似乎在承诺解决之前跳转到下一个函数(或链中的 'link')。有什么方法可以让它在跳转到下一个函数之前等待这个嵌套的 属性 解决?
fetch(prefix + '/download', {
method: 'POST',
.....
})
.then((response) => {
var contentDisposition = response.headers.get('content-disposition');
var fileName = contentDisposition.split('filename=')[1].split(';')[0];
return { blob: response.blob(), filename: fileName }
})
.then((blob) => {
return { href: URL.createObjectURL(blob.blob), filename: blob.filename }
})
我收到 Failed to execute 'createObjectURL' on 'URL': No function was found that matched the signature provided.
,大概是因为 blob.blob return 是一个 Promise,还没有任何价值。
尝试return在response.blob()
承诺中用自己的then()
到return最终数据
fetch(prefix + '/download', {
method: 'POST',
.....
})
.then((response) => {
var contentDisposition = response.headers.get('content-disposition');
var filename = contentDisposition.split('filename=')[1].split(';')[0];
return response.blob().then(blob =>{
return { href: URL.createObjectURL(blob), filename}
});
});
我正在尝试 return 一个具有两个属性的对象...其中一个正在生成 blob,需要时间来解析。然而 javascript 似乎在承诺解决之前跳转到下一个函数(或链中的 'link')。有什么方法可以让它在跳转到下一个函数之前等待这个嵌套的 属性 解决?
fetch(prefix + '/download', {
method: 'POST',
.....
})
.then((response) => {
var contentDisposition = response.headers.get('content-disposition');
var fileName = contentDisposition.split('filename=')[1].split(';')[0];
return { blob: response.blob(), filename: fileName }
})
.then((blob) => {
return { href: URL.createObjectURL(blob.blob), filename: blob.filename }
})
我收到 Failed to execute 'createObjectURL' on 'URL': No function was found that matched the signature provided.
,大概是因为 blob.blob return 是一个 Promise,还没有任何价值。
尝试return在response.blob()
承诺中用自己的then()
到return最终数据
fetch(prefix + '/download', {
method: 'POST',
.....
})
.then((response) => {
var contentDisposition = response.headers.get('content-disposition');
var filename = contentDisposition.split('filename=')[1].split(';')[0];
return response.blob().then(blob =>{
return { href: URL.createObjectURL(blob), filename}
});
});