xgqfrms™, xgqfrms® : xgqfrms's offical website of GitHub!

convert image to base64 in javascript


"use strict";

/**
 *
 * @author xgqfrms
 * @license MIT
 * @copyright xgqfrms
 * @created 2020-05-16
 * @modified
 *
 * @description convert image to base64 in javascript
 * @augments
 * @example
 * @link
 *
 */

const log = console.log;

function getDataUrl(img) {
  // Create canvas
  const canvas = document.createElement('canvas');
  const ctx = canvas.getContext('2d');
  // Set width and height
  canvas.width = img.width;
  canvas.height = img.height;
  // Draw the image
  ctx.drawImage(img, 0, 0);
  return canvas.toDataURL('image/jpeg');
}

// Select the image
// const img = document.querySelector('#my-image');
// img.addEventListener('load', function (event) {
//   const dataUrl = getDataUrl(event.currentTarget);
//   console.log(dataUrl);
// });


demo

https://cdn.xgqfrms.xyz/

const log = console.log;

function getDataUrl(img) {
  // Create canvas
  const canvas = document.createElement('canvas');
  const ctx = canvas.getContext('2d');
  // Set width and height
  canvas.width = img.width;
  canvas.height = img.height;
  // Draw the image
  ctx.drawImage(img, 0, 0);
  return canvas.toDataURL('image/png');
  // return canvas.toDataURL('image/webp');
  // return canvas.toDataURL('image/jpeg');
}

img = document.querySelectorAll(`img`)[37];

base64Result = ``;

img.addEventListener('click', function (event) {
  console.log(`event`, event)
  console.log(`event.currentTarget`, event.currentTarget)
  const dataUrl = getDataUrl(event.currentTarget);
  console.log(dataUrl);
  try {
     // window.copy(dataUrl);
     base64Result = dataUrl;
     log(`auto copy success!`)
  } catch (err) {
    log(err)
 }
});


copy(base64Result);





Flag Counter

©xgqfrms 2012-2020

www.cnblogs.com 发布文章使用:只允许注册用户才可以访问!


原文地址:https://www.cnblogs.com/xgqfrms/p/12903214.html