如何将网页引入的 SVG 文件转换为代码形式?

如何将网页引入的 SVG 文件转换为代码形式?

如何将网页引入的svg转换为代码形式

在网页中引入svg文件后,源代码通常只会显示一个文件路径,例如./test.svg。而其他网站引入svg时,却是一大串编码。如何实现这种编码引入方式呢?

解决方案:

通过使用JavaScript的fetch()和DOMParser(),我们可以将svg文件转换为代码形式。具体步骤如下:

  1. 使用fetch()获取svg文件的文本内容。
  2. 使用text()方法将响应体转换为文本。
  3. 使用DOMParser()将文本解析为xml文档。
  4. 从xml文档中获取svg元素。

以下是示例代码:

<div id="test"></div>
fetch('https://static.segmentfault.com/main_site_next/614d2165/_next/static/media/sf-icon-small.4d244289.svg')
    .then(body => body.text())
    .then(svg => (new DOMParser).parseFromString(svg, 'image/svg+xml'))
    .then(actualSVG => {
        // append to the body or do your thing
        document.querySelector('#test').appendChild(actualSVG.documentElement)
    });

使用此方法,我们可以将网页引入的svg文件转换为代码,方便我们进一步操作或修改。

以上就是如何将网页引入的 SVG 文件转换为代码形式?的详细内容,更多请关注其它相关文章!