亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 開發 > JS > 正文

JavaScript 下載svg圖片為png格式

2024-05-06 16:44:59
字體:
來源:轉載
供稿:網友

1.遇到需要將svg下載的需求,網上找了一些代碼,地址是這個https://github.com/exupero/saveSvgAsPng,但是不太好用,莫名的把網頁所有的svg都下載了,于是在源碼的基礎上做了一些小的修改;代碼如下所示

var doctype = '<?xml version="1.0" standalone="no"?><!DOCTYPE svg PUBLIC "-//W3C//DTD SVG 1.1//EN" "http://www.w3.org/Graphics/SVG/1.1/DTD/svg11.dtd" [<!ENTITY nbsp " ">]>'; function convertToPng(src, w, h) {       var canvas = document.createElement('canvas');       var context = canvas.getContext('2d');       canvas.width = w;       canvas.height = h;       context.drawImage(src, 0, 0);       var png;       try {         png = canvas.toDataURL("image/png");       } catch (e) {         if ((typeof SecurityError !== 'undefined' && e instanceof SecurityError) || e.name == "SecurityError") {           console.error("Rendered SVG images cannot be downloaded in this browser.");           return;         } else {           throw e;         }       }       return png;     }     function isElement(obj) {       return obj instanceof HTMLElement || obj instanceof SVGElement;     }     function reEncode(data) {       data = encodeURIComponent(data);       data = data.replace(/%([0-9A-F]{2})/g, function (match, p1) {         var c = String.fromCharCode('0x' + p1);         return c === '%' ? '%25' : c;       });       return decodeURIComponent(data);     }     function uriToBlob(uri) {       var byteString = window.atob(uri.split(',')[1]);       var mimeString = uri.split(',')[0].split(':')[1].split(';')[0]       var buffer = new ArrayBuffer(byteString.length);       var intArray = new Uint8Array(buffer);       for (var i = 0; i < byteString.length; i++) {         intArray[i] = byteString.charCodeAt(i);       }       return new Blob([buffer], {type: mimeString});     }     function downLoad(el, name) {       if (!isElement(el)) {         throw new Error('an HTMLElement or SVGElement is required; got ' + el);       }       if (!name) {         console.error("文件名為空!");         return;       }       var xmlns = "http://www.w3.org/2000/xmlns/";       var clone = el.cloneNode(true);       clone.setAttribute("version", "1.1");       if (!clone.getAttribute('xmlns')) {         clone.setAttributeNS(xmlns, "xmlns", "http://www.w3.org/2000/svg");       }       if (!clone.getAttribute('xmlns:xlink')) {         clone.setAttributeNS(xmlns, "xmlns:xlink", "http://www.w3.org/1999/xlink");       }       var svg = clone.outerHTML;       var uri = 'data:image/svg+xml;base64,' + window.btoa(reEncode(doctype + svg));       var image = new Image();       image.onload = function () {         var png = convertToPng(image, image.width, image.height);         var saveLink = document.createElement('a');         var downloadSupported = 'download' in saveLink;         if (downloadSupported) {           saveLink.download = name + ".png";           saveLink.style.display = 'none';           document.body.appendChild(saveLink);           try {             var blob = uriToBlob(png);             var url = URL.createObjectURL(blob);             saveLink.href = url;             saveLink.onclick = function () {               requestAnimationFrame(function () {                 URL.revokeObjectURL(url);               })             };           } catch (e) {             saveLink.href = uri;           }           saveLink.click();           document.body.removeChild(saveLink);         }       };       image.src = uri;     } 

這里使用的時候只需要調用download方法就可以了,建議封裝成一個單獨的下載服務;download方法的第一個參數el指的是dom元素,就是svg元素,具體的獲取方法通過js或者d3的選擇器都可以;例如

<div id="svg-parent-div"><svg>...</svg></div> 

一般通過獲取svg的父元素來找到它,比如

var el = d3.select("#svg-parent-div").node().children[0]; download(el,"下載圖片"); 

這樣就可以了;

代碼對于svg的沒設置命名空間的情況做了處理,通過如下代碼,如果svg 元素沒有 設置命名空間,則添加; 

el.setAttributeNS(xmlns, "xmlns", "http://www.w3.org/2000/svg"); el.setAttributeNS(xmlns, "xmlns:xlink", "http://www.w3.org/1999/xlink"); 

同時,添加的命名空間作用在clone的元素上,不會影響原來的svg元素;

總結

以上所述是小編給大家介紹的JavaScript 下載svg圖片為png格式,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復大家的。在此也非常感謝大家對VeVb武林網網站的支持!


注:相關教程知識閱讀請移步到JavaScript/Ajax教程頻道。
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
色综合久综合久久综合久鬼88| 日本久久精品视频| 欧美性xxxxx| 欧美成人精品一区| 日韩视频在线一区| 亚洲丝袜av一区| 久久精品亚洲一区| 久久影院中文字幕| 国产一区二区三区精品久久久| 国产精品免费久久久久影院| 欧美日韩国产在线看| 国产精品电影一区| 亚洲国产精久久久久久| 97免费在线视频| 欧美日韩第一页| 国产精品爽爽ⅴa在线观看| 亚洲伊人久久大香线蕉av| 精品色蜜蜜精品视频在线观看| 国产精品自产拍在线观看| 国产精品2018| 成人亲热视频网站| 亚洲午夜av久久乱码| 国产精品7m视频| 日韩成人激情在线| 91精品国产高清久久久久久久久| 成人国产精品久久久| 国产综合福利在线| 国产视频在线观看一区二区| 美女国内精品自产拍在线播放| 成人动漫网站在线观看| 久久中文字幕视频| 日韩视频第一页| 久久精品国产亚洲| 91精品在线观| 欧美在线免费视频| 国产91色在线| 成人a免费视频| 97精品久久久中文字幕免费| 国产日韩在线一区| 国产亚洲日本欧美韩国| 国产精品xxx视频| 国产成人在线一区| 亚洲国产成人精品久久| 亚洲天天在线日亚洲洲精| 日韩性生活视频| 黑人巨大精品欧美一区二区一视频| 欧美成人黄色小视频| 国产日韩欧美夫妻视频在线观看| 欧洲成人在线观看| 日本三级韩国三级久久| 黄色一区二区在线观看| 国产精品福利在线| 国产精品r级在线| 3344国产精品免费看| 中文日韩在线观看| 色综合五月天导航| 国产精品美女网站| 日韩在线视频免费观看高清中文| 欧美一级电影久久| 亚洲最大福利视频网站| 色综合久久88色综合天天看泰| 疯狂欧美牲乱大交777| 欧美视频免费在线观看| 日韩黄在线观看| 国产精品综合网站| 精品亚洲国产成av人片传媒| 欧美日韩激情视频8区| 欧美大片在线影院| 成人写真福利网| 亚洲精品国产欧美| 麻豆国产精品va在线观看不卡| 精品视频在线导航| 国产精品日日做人人爱| 81精品国产乱码久久久久久| 国产91精品网站| 久久精品人人做人人爽| 日本精品一区二区三区在线播放视频| 精品视频久久久久久久| 疯狂做受xxxx欧美肥白少妇| 青青久久av北条麻妃黑人| 国产91在线高潮白浆在线观看| 91在线视频精品| 国产亚洲精品一区二555| 日韩中文在线不卡| 136fldh精品导航福利| 日韩欧美a级成人黄色| 97久久伊人激情网| 日韩中文字幕欧美| 欧美在线视频免费播放| 日韩精品高清在线观看| 欧美极品xxxx| 深夜福利国产精品| 国产拍精品一二三| 国产91免费看片| 日韩欧美国产骚| 国产精品精品久久久| 国产精品视频自拍| 日韩风俗一区 二区| 欧美疯狂xxxx大交乱88av| 国产亚洲精品成人av久久ww| 欧美孕妇毛茸茸xxxx| 55夜色66夜色国产精品视频| 亚洲精品国产精品国自产在线| 亚洲国产精久久久久久久| 久久久久久久久国产| 国产美女高潮久久白浆| 九九热精品视频| 98午夜经典影视| 日韩欧美中文免费| 国产亚洲欧美日韩精品| 国产一区二区在线播放| 亚洲影院色无极综合| 日韩免费在线看| 中文综合在线观看| 免费av一区二区| 久久久久久国产精品三级玉女聊斋| 日韩av一卡二卡| 欧美日韩国产在线看| 中文字幕亚洲国产| 欧美日韩亚洲精品一区二区三区| 97视频在线免费观看| 久久久久久亚洲精品不卡| 欧美性猛交xxxx黑人| 色综久久综合桃花网| 久久99青青精品免费观看| 国产精品久久久精品| 日本精品久久久久久久| 国产精品va在线| 久久久精品999| 国产黑人绿帽在线第一区| 久久久亚洲天堂| 国产激情综合五月久久| 国内精品久久久久| 日韩精品在线观看视频| 日韩高清电影免费观看完整| 亚洲美女在线看| 日韩在线视频播放| 亚洲人成网站色ww在线| 中文字幕亚洲无线码在线一区| 日韩电影大全免费观看2023年上| 成人av电影天堂| 日韩一级裸体免费视频| 亚洲xxxx妇黄裸体| 性色av一区二区咪爱| 91极品女神在线| 国产丝袜高跟一区| 黄色成人av网| 国产69久久精品成人| 久99久在线视频| 日韩高清a**址| 国内精品一区二区三区四区| 欧美成年人网站| 成人免费视频xnxx.com| 成人a在线观看| 狠狠色香婷婷久久亚洲精品| 欧美在线观看视频| 欧美自拍大量在线观看| 午夜伦理精品一区| 久久久av亚洲男天堂| 国产日韩在线精品av| 2023亚洲男人天堂| 亚洲欧美中文日韩v在线观看| 亚洲欧美中文字幕在线一区| 国产精品香蕉国产|