[Javascript]Svg、Png转Base64大法

[Javascript]Svg、Png转Base64大法

使用 Base64 编码的优点:

  1. 减少 HTTP 请求:使用 Base64 编码可以将图像嵌入到 HTML、CSS 或 JavaScript 中,避免了额外的 HTTP 请求,从而提高网站性能。
  2. 减小文件大小:通过使用 Base64 编码,图像文件的大小将增加约 33%,但是,通过避免额外的 HTTP 请求,可以减少响应时间和带宽消耗。
  3. 支持跨域:使用 Base64 编码的图像可以在不同的域中使用,避免了跨域请求的问题。
  4. 简化开发流程:使用 Base64 编码可以简化开发流程,因为你不需要处理图像文件的加载和管理,只需要将其嵌入到 HTML、CSS 或 JavaScript 中即可。
  5. 提高安全性:使用 Base64 编码可以提高安全性,因为你可以避免在网站中包含外部图像文件的风险,例如恶意软件或跟踪像素。

需要注意的是,使用 Base64 编码的图像可能会增加 HTML、CSS 或 JavaScript 文件的大小,因此需要在性能和文件大小之间进行权衡。此外,使用 Base64 编码的图像可能会影响可维护性和可读性,因为你需要将其嵌入到文本中,而不是作为单独的文件进行管理。

根据Svg代码转Base64

js 复制代码
const svgToBase64 = (svgCode)=>{
    const base64Code = btoa(svgCode);
    const base64SVG = `data:image/svg+xml;base64,${base64Code}`
    return base64SVG
}

使用实例:

js 复制代码
svgToBase64 (`<svg width="12" height="10" viewBox="0 0 12 10" fill="none" xmlns="http://www.w3.org/2000/svg">
  <path fill-rule="evenodd" clip-rule="evenodd"
    d="M11.747 1.95918L4.68715 9.43428L0.252441 4.99957L1.66665 3.58536L4.64616 6.56487L10.2929 0.585938L11.747 1.95918Z"
    fill="#004FD6" />
</svg>`)

输出:

js 复制代码
''

根据Png图片路径转Base64

js 复制代码
function convertPNGtoBase64(url, callback) {
  const img = new Image();
  img.crossOrigin = 'Anonymous'; // 跨域设置
  img.onload = function() {
    const canvas = document.createElement('canvas');
    canvas.width = img.width;
    canvas.height = img.height;
    const ctx = canvas.getContext('2d');
    ctx.drawImage(img, 0, 0);
    const base64PNG = canvas.toDataURL();
    callback(base64PNG);
  };
  img.src = url;
}

将PNG图片转为Base64编码的函数示例

js 复制代码
convertPNGtoBase64('path/to/image.png', function(base64PNG) {
  console.log(base64PNG);
});

根据Dom转Base64

js 复制代码
 const myImg = document.getElementById('myImg'); // 获取Img
 // #### Canvas 转 Base64
 function canvasBase64() {
   const canvas = document.getElementById('myCanvas');
   const ImgBase64 = canvas.toDataURL('image/png');
   console.log(ImgBase64, 'Canvas 转 Base64');
   myImg.src = ImgBase64;
 }
 // #### Svg 转 Base64
 function svgBase64() {
   const svg = document.getElementById('mySvg');
   const s = new XMLSerializer().serializeToString(svg);
   const ImgBase64 = `data:image/svg+xml;base64,${window.btoa(s)}`;
   console.log(ImgBase64, 'Svg 转 Base64');
   myImg.src = ImgBase64;
 }
 // #### Svg 转 png
 function svgPng() {
   const svg = document.getElementById('mySvg');
   const s = new XMLSerializer().serializeToString(svg);
   const src = `data:image/svg+xml;base64,${window.btoa(s)}`;
   const img = new Image(); // 创建图片容器承载过渡
   img.src = src;
   img.onload = () => {
     // 图片创建后再执行,转Base64过程
     const canvas = document.createElement('canvas');
     canvas.width = img.width;
     canvas.height = img.height;
     const context = canvas.getContext('2d');
     context.drawImage(img, 0, 0);
     const ImgBase64 = canvas.toDataURL('image/png');
     console.log(ImgBase64, 'Svg 转 png');
     myImg.src = ImgBase64;
   }
 }
​
相关推荐
牧码岛11 分钟前
Web前端之Vue+Element打印时输入值没有及时更新dom的问题
前端·javascript·html·web·web前端
代码游侠12 分钟前
学习笔记——数据结构学习
linux·开发语言·数据结构·笔记·学习
小二李17 分钟前
第8章 Node框架实战篇 - 文件上传与管理
前端·javascript·数据库
沐知全栈开发21 分钟前
XML 验证器
开发语言
自学互联网44 分钟前
使用Python构建钢铁行业生产监控系统:从理论到实践
开发语言·python
合作小小程序员小小店1 小时前
桌面开发,在线%医院管理%系统,基于vs2022,c#,winform,sql server数据
开发语言·数据库·sql·microsoft·c#
一点★1 小时前
“equals”与“==”、“hashCode”的区别和使用场景
java·开发语言
十一.3661 小时前
79-82 call和apply,arguments,Date对象,Math
开发语言·前端·javascript
霍格沃兹测试开发学社-小明1 小时前
测试左移2.0:在开发周期前端筑起质量防线
前端·javascript·网络·人工智能·测试工具·easyui
合作小小程序员小小店1 小时前
桌面开发,下午茶甜品管理系统开发,基于C#,winform,sql server数据库
开发语言·数据库·sql·microsoft·c#