javascript - 如何在 jQuery 中将预加载的图像转换为 Base64 数据

标签 javascript jquery base64

我指的是Get image data in JavaScript?

使用 jQuery,我想将预加载的 img 转换为 Base64 编码数据。我按照以下方式尝试了在提到的网址中找到的函数,但出现了错误。

我从提到的链接中找到的函数:

function getBase64Image(img) {
    // Create an empty canvas element
    var canvas = document.createElement("canvas");
    canvas.width = img.width;
    canvas.height = img.height;

    // Copy the image contents to the canvas
    var ctx = canvas.getContext("2d");
    ctx.drawImage(img, 0, 0);

    // Get the data-URL formatted image
    // Firefox supports PNG and JPEG. You could check img.src to
    // guess the original format, but be aware the using "image/jpg"
    // will re-encode the image.
    var dataURL = canvas.toDataURL("image/png");

    return dataURL.replace(/^data:image\/(png|jpg);base64,/, "");
}

我如何尝试:

var a = $('[active_contact][serial=1] img');
console.log(get_base64_image(a));

我从 firbug 控制台收到的错误:

TypeError: Argument 1 of CanvasRenderingContext2D.drawImage could not be converted to any of: HTMLImageElement, HTMLCanvasElement, HTMLVideoElement.
get_base64_image()

ctx.drawImage(img, 0, 0);

我怎样才能让这个东西发挥作用?我想使用 jQuery 将预加载的图像转换为 base64 以供重复使用。有更好的想法欢迎提出。

最佳答案

确保您传入实际的 Image 元素(并且它已正确加载):

var a = $('[active_contact][serial=1] img')[0]; // notice [0] at the end = image

关于javascript - 如何在 jQuery 中将预加载的图像转换为 Base64 数据,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/27099677/

相关文章:

javascript - 如何使用javascript将图像保存在解析云中

javascript - 在 node.js 中解码 Base64 字符串

javascript - 旋转元素也会改变 css 动画中的 scaleX

jquery - 使用 jQuery 删除 Bootstrap 缩略图

javascript - JavaScript 中的哪些对象具有 .length 属性? (也就是为什么 Underscore _.each 把我的函数对象当作一个数组来对待?)

javascript - 为 css 启用版本控制时 css 背景图像的版本

javascript - 由于图像大小不同,带有幻灯片的 slider 会自行调整大小

uiimage - 将 base64 数据解码为图像

javascript - HR infotype itab 行的条件循环清除?

javascript - 谷歌注释时间线 : "Error: Container width is zero. Expecting a valid width."