<svg height="160" width="400" xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink">
<image xlink:href=""/>
</svg>
对于<foreignObject>标签中的html元素也一样。
两者结合可以将html节点转换成为图片
<foreignObject>标签<foreignObject>是SVG的一个子标签,这个标签中可以用于显示普通的DOM标签。也就是渲染XHTML元素。举个例子:<svg xmlns="http://www.w3.org/2000/svg"> <foreignObject width="120" height="50"> <body xmlns="http://www.w3.org/1999/xhtml">
随时随地将SVG转换为base64
如果像我一样,在开发时使用了大量的SVG,则可能已经到了需要将SVG用作背景图像或嵌入到javascript文件中的地步。 唯一的方法是将SVG文件转换为base64字符串,然后在需要时使用它。 该软件包正是这样做的-将SVG转换为base64。
该软件包可在浏览器和Node环境中使用。 请继续阅读以了解操作方法。
npm i svg64
yarn add svg64
只需下载此存储库并使用dist文件夹中的文件
或从unpkg.com取消设置
< script src =" https://unpkg.com/svg64 " > </ script >
在浏览器中:
// This is your SVG DOM element
const svg = document . getElementByI
let that = this;
let chart = document.getElementById('chart');
let svghtml = chart.innerHTML;
// let svg = document.querySele...
methods: {
onOK() {
//调用转换方法 svgBase64为svgbase64的数据 格式:data:image/svg+xml;base64,..................
let pngBase64Fun = this.svgBase64ToPngBase64(svgBase64);
pngBase64Fun.then((res) => {
// 将svg base64转 pngbase64后执行回调函数,res 为转换后的png
private function saveBase64($base64_image_content){
if (preg_match('/^(data:\s*image\/(\w+);base64,)/', $base64_image_content, $result)){
//图片后缀
$type = $r...
令人发指的构建包
看了很多相关的技术文章,大多数用 html2canvas.js 和 canvas.js 第三方包实现,有些用了像 D3.js 这样更大型的构建包,而实际用到的功能,却只是其中 1% 都不足,简直就是令人发指。
综合文章中转换过程的设计思想,自己干,10行代码搞定!
svg 先转 canvas 再转 base64
一:了解一下 canvas 转 Base64
con...
第一种是svg内部都是使用svg的方法进行绘制的,我们可以直接通过canvas的方法进行绘制下载,方法如下
第二种情况是在svg内部嵌套了一个image的图片,此时则无法使用第一种方法直接进行下载,下载的图片无内嵌图片,后来通过调查发下,需要把image引入的图片的路径更改微base64的方法后,再进行下载则可以实现,并解决问题。方法如下。
通过此种方法就可以解决svg内部嵌套image图片下载
转换链接:https://www.sojson.com/image2base64.html
2、使用两者区别
(1)使用一个63.8k的svg与使用转base64之后的两个文件
a、使用svg
b、使用base64
(2)使用一个225k的svg与使用转base64之后的两个文件
a、使用svg
b、使用base64
3、svg转base64有什么好处吗?
(1)减少http
之前做了一个svg简易的编辑器!有个需求将编辑器编辑好的svmXml代码转成图片然后上传到图片服务器!在网上招了好多的例子!发现大部分都要用到第三方的js插件!所以为了方便就自己写了个简单点的!下面分享出来!也算自己的一个笔记吧!
直接上页面部分代码:
div中就是你的svg x...