Img url使用JavaScript进行dataurl

问题描述 投票:4回答:3

使用JavaScript,我想转换像这样的img标签:

<img width="11" height="14" src="http://mysite/file.gif" alt="File Icon">

进入一个像这样的dataurl:

<img width="11" height="14" src=" gcEIQA7" alt="File Icon">

这可能吗?

javascript html5 image data-uri
3个回答
8
投票

首先,将图像加载到画布中

var canvas = document.createElement("canvas");
context = canvas.getContext('2d');

make_base();

function make_base()
{
  base_image = new Image();
  base_image.src = 'img/base.png';
  base_image.onload = function(){
    context.drawImage(base_image, 100, 100);
  }
}

确保将context.drawImage(base_image, 100, 100);更新为适合您应用的值。

资料来源:https://stackoverflow.com/a/6011402/3969707

然后将画布转换为数据。

var jpegUrl = canvas.toDataURL("image/jpeg");
var pngUrl = canvas.toDataURL(); // PNG is the default

资料来源:https://stackoverflow.com/a/15685877/3969707


0
投票

这真的不是你可能想要在JavaScript中做的事情,因为它需要在JavaScript中解析图像非常慢。您将加载图像,然后将函数的输出放入img标记,这不会节省带宽,降低复杂性或提高安全性。

你最好的选择是做这个服务器端。我过去曾经用它来取得巨大的成功,因为它生成的页面需要绝对没有链接/引用的外部资源。对于jsPDF,您可以使用原始JavaScript或jQuery来获取图像数据以传递到PDF创建过程。

这将适用于所有地方,而不是依赖于没有完整移动浏览器支持的canvas


0
投票

以下是如何使用fetch获取图像的数据网址:

(async function() {
    let blob = await fetch("https://example.com/image.png").then(r => r.blob());
    let dataUrl = await new Promise(resolve => {
      let reader = new FileReader();
      reader.onload = () => resolve(reader.result);
      reader.readAsDataURL(blob);
    });
    // now do something with `dataUrl`
})();
© www.soinside.com 2019 - 2024. All rights reserved.