gpt4 book ai didi

javascript - 关于使用 JavaScript 从外部 url 显示图像的不同方式的困惑

转载 作者:行者123 更新时间:2023-12-05 00:25:19 26 4
gpt4 key购买 nike

我最近了解到似乎有多种方法可以在网页上显示图像。
第一种方法是直接将 URL 分配给图像元素的 URL

const img = new Image();

img.onload = () => {
document.querySelector("#myImage").src = url;
};
img.onerror = () => {};

img.src = imageUrl;
我最近学到的另一种方法是使用 fetch
fetch(imageUrl)
.then((response)=>response.blob())
.then((blob)=>{
const objectUrl = URL.createObjectURL(blob)
document.querySelector("#myImage").src = objectUrl;
})
我对这两种方法有几个问题:
  • 我熟悉fetch但我通常用它来获取 JSON。第二种使用方式fetch在我看来,获取图像就像我们通过 HTTP 获取该图像文件的原始二进制数据,而第一个我们委托(delegate)浏览器启动 Get请求获取该图像。但是从服务器的 Angular 来看,它如何向下发送图像没有区别吗?我理解对了吗?
  • 在什么情况下,我们应该倾向于一种方法而不是另一种?我觉得第二种方法会比第一种方法有很多 CORS 问题,但不确定原因。
  • 还有其他方法可以在网页上显示图像吗?当人们谈论图像时,我经常听说 base64 编码/解码。 base64 是否与 response.blob() 相关?即第二种方法?还是不一样?如果是这样,有人可以给我一个使用base64显示图像的例子吗?
  • 最后,我认为显示图像是我前端或 Web 开发知识的一个漏洞。请随时推荐有关此主题的任何好的资源。
  • 最佳答案

    回答您的问题

  • 与服务器端基本相同,除了浏览器可以发送的标题和信息,而在 fetch 中,您可以完全控制标题
  • fetch 方法可用于更灵活或更进一步的参数,这些参数需要您可能在服务器中实现的请求或安全传输。例如,要求具有包含某些数据的 header 或正文的发布请求以允许传输图像......或灵活传输,例如可以放入 block 中的数据,您以后可以在呈现之前组装和操作。
  • 使用 base64 几乎与二进制相同,尽管它用于通过旨在传输文本的介质传输图像/数据。这是因为 base64 使用 ascii 数字和字母来表示任何数据。

  • 在这里,您可以看到由base64字符串字符生成的图像,没有任何链接

    <img style="width:64px; height:64px;" src=""></img>

    这也有助于将图像作为文本直接嵌入代码中,将其作为 url 参数传递,或者您甚至可以将图像放入 JSON 文件。在某些情况下,它也比使用 gzip 压缩的二进制图像执行得更好。

    关于javascript - 关于使用 JavaScript 从外部 url 显示图像的不同方式的困惑,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/69512769/

    26 4 0
    Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
    广告合作:1813099741@qq.com 6ren.com