我想尝试下载图像单击按钮,但是当我单击按钮时,这不是下载图像而是直接打开图像,但我想下载图像,那么如何在 reactjs 中下载图像?
<a
href="https://timesofindia.indiatimes.com/thumb/msid-70238371,imgsize-89579,width-400,resizemode-4/70238371.jpg"
download
>
<i className="fa fa-download" />
</a>
我想尝试下载图像单击按钮,但是当我单击按钮时,这不是下载图像而是直接打开图像,但我想下载图像,那么如何在 reactjs 中下载图像?
<a
href="https://timesofindia.indiatimes.com/thumb/msid-70238371,imgsize-89579,width-400,resizemode-4/70238371.jpg"
download
>
<i className="fa fa-download" />
</a>
遇到了这个试图弄清楚如何下载 png 图像的问题,发现另一个答案对我来说不太合适,因为无法打开下载的文件。需要使用 arraybuffer 来转换图像。
这是有效的代码。
function App() {
const download = e => {
console.log(e.target.href);
fetch(e.target.href, {
method: "GET",
headers: {}
})
.then(response => {
response.arrayBuffer().then(function(buffer) {
const url = window.URL.createObjectURL(new Blob([buffer]));
const link = document.createElement("a");
link.href = url;
link.setAttribute("download", "image.png"); //or any other extension
document.body.appendChild(link);
link.click();
});
})
.catch(err => {
console.log(err);
});
};
return (
<div className="App">
<a
href="https://upload.wikimedia.org/wikipedia/en/6/6b/Hello_Web_Series_%28Wordmark%29_Logo.png"
download
onClick={e => download(e)}
>
<i className="fa fa-download" />
download
</a>
</div>
);
}
代码沙盒:https ://codesandbox.io/s/dreamy-gould-h1l72
PS 下载方法取自这个回复,但使用了plain fetch 而不是axios。 https://stackoverflow.com/a/50220546/10006323
你可以这样做:
function App() {
const download = () => {
var element = document.createElement("a");
var file = new Blob(
[
"https://timesofindia.indiatimes.com/thumb/msid-70238371,imgsize-89579,width-400,resizemode-4/70238371.jpg"
],
{ type: "image/*" }
);
element.href = URL.createObjectURL(file);
element.download = "image.jpg";
element.click();
};
return (
<div className="App">
<a
href="https://timesofindia.indiatimes.com/thumb/msid-70238371,imgsize-89579,width-400,resizemode-4/70238371.jpg"
download
onClick={() => download()}
>
<i className="fa fa-download" />
download
</a>
</div>
);
}
这是工作网址:https : //codesandbox.io/s/clever-noether-3nu2p? fontsize =14
注意:可以做更多的事情。我刚刚为演示目的创建了这个
安装文件保护程序包:
npm i file-saver
你的react组件:
import { saveAs } from 'file-saver'
const Index = () => {
const downloadImage = () => {
saveAs('image_url', 'image.jpg') // Put your image url here.
}
return <Button onClick={downloadImage}>Download!</Button>
}
这是下载带有 URL 和动态名称的图像的示例。
const download = async() => {
const originalImage="https://cdn1.iconfinder.com/data/icons/ninja-things-1/1772/ninja-simple-512.png";
const image = await fetch(originalImage);
//Split image name
const nameSplit=originalImage.split("/");
const duplicateName=nameSplit.pop();
const imageBlog = await image.blob()
const imageURL = URL.createObjectURL(imageBlog)
const link = document.createElement('a')
link.href = imageURL;
link.download = ""+duplicateName+"";
document.body.appendChild(link)
link.click()
document.body.removeChild(link)
};