Img url使用JavaScript进行dataurl

ada*_*101 6 javascript html5 image data-uri

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

<img width="11" height="14" src="http://mysite/file.gif" alt="File Icon">
Run Code Online (Sandbox Code Playgroud)

进入一个像这样的dataurl:

<img width="11" height="14" src=" gcEIQA7" alt="File Icon">
Run Code Online (Sandbox Code Playgroud)

这可能吗?

小智 25

以下是如何使用以下命令获取图像的数据 url 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`
})();
Run Code Online (Sandbox Code Playgroud)


小智 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);
  }
}
Run Code Online (Sandbox Code Playgroud)

确保更新context.drawImage(base_image, 100, 100);适合您的应用程序的to值.

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

然后将画布转换为数据.

var jpegUrl = canvas.toDataURL("image/jpeg");
var pngUrl = canvas.toDataURL(); // PNG is the default
Run Code Online (Sandbox Code Playgroud)

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


Âng*_*tto 5

我将使用与加载的图像大小相同的临时画布元素来解决这个问题:

function imageToUri(url, callback) {
    const canvas = document.createElement('canvas');
    const ctx = canvas.getContext('2d');

    var base_image = new Image();
    base_image.src = url;
    base_image.onload = function() {
        canvas.width = base_image.width;
        canvas.height = base_image.height;

        ctx.drawImage(base_image, 0, 0);
    
        callback(canvas.toDataURL('image/png'));

        canvas.remove();
    }
}

imageToUri('./assets/some_image.png', function(uri) {
    console.log(uri);
});
Run Code Online (Sandbox Code Playgroud)