本地 png 图片地址如何转base64?

/aaaaa/static/img/zhexian.41eafbf5.png 转 这种格式


阅读 3.3k
5 个回答
// 把本地图片文件路径转换为 Base64 编码字符串
async function imageToBase64(imagePath) {
  const response = await fetch(imagePath);
  const blob = await response.blob();
  return new Promise((resolve, reject) => {
    const reader = new FileReader();
    reader.onloadend = () => resolve(reader.result);
    reader.onerror = reject;
    reader.readAsDataURL(blob);
  });
}


imageToBase64('/aaaaa/static/img/zhexian.41eafbf5.png')
  .then((base64) => {
    console.log(base64); // 输出 Base64 编码字符串
  })
  .catch((error) => {
    console.error('Error converting image to base64:', error);
  });
新手上路,请多包涵

你的图片是用户选取的嘛
试试这样
const fileInput = document.getElementById("fileInput");

const reader = new FileReader();

fileInput.onchange = (e) => {

reader.readAsDataURL(e.target.files[0]);

}

reader.onload = (e) => {

console.log(e.target.result);

}

图片转base64方法

 getBase64(imgUrl, callback) {
      let image = new Image();
      // 解决跨域问题
      image.setAttribute("crossOrigin", "anonymous");
      let imageUrl = imgUrl;
      image.src = imageUrl;
      // image.onload为异步加载
      image.onload = function() {
        var canvas = document.createElement("canvas");
        canvas.width = image.width;
        canvas.height = image.height;
        var context = canvas.getContext("2d");
        // eslint-disable-next-line no-undef
        context.drawImage(image, 0, 0, image.width, image.height);
        var quality = 0.8;
        // 这里的dataurl就是base64类型
        // 使用toDataUrl将图片转换成jpeg的格式,不要把图片压缩成png,因为压缩成png后              base64的字符串可能比不转换前的长!
        let dataurl = canvas.toDataURL("image/jpeg", quality);
        callback ? callback(dataurl) : null; //调用回调函数
      };
 }

使用:

this.getBase64('./test.img', dataURL => {
      console.log(dataURL );
 })
撰写回答
你尚未登录,登录后可以
  • 和开发者交流问题的细节
  • 关注并接收问题和回答的更新提醒
  • 参与内容的编辑和改进,让解决方法与时俱进
推荐问题
宣传栏