我正在使用<use xlink:href>
来引用我的svg
文件。
它在我的本地运行良好,但当我从 CDN 引用它时会引发错误 (CORS)。看起来好像xlink:href
不允许CORS请求,但我想知道是否有任何解决方案?
另一方面,我听说这种精灵技术在SVG2上已被弃用。那么,目前使用 sprite SVG 文件的最佳解决方案是什么,它适用于所有不同的浏览器,包括移动浏览器。
我正在使用<use xlink:href>
来引用我的svg
文件。
它在我的本地运行良好,但当我从 CDN 引用它时会引发错误 (CORS)。看起来好像xlink:href
不允许CORS请求,但我想知道是否有任何解决方案?
另一方面,我听说这种精灵技术在SVG2上已被弃用。那么,目前使用 sprite SVG 文件的最佳解决方案是什么,它适用于所有不同的浏览器,包括移动浏览器。
我发现的最简单的跨浏览器解决方案是通过 ajax 获取 SVG sprite 并将其嵌入到您的页面中:
<div id="svg-container" style="display: none"></div>
<script>
!function() {
var xhr = new XMLHttpRequest();
xhr.open("GET", '/path/to/cdn/sprite.svg');
xhr.onload = function() {
document.getElementById('svg-container').innerHTML = xhr.responseText;
}
xhr.send();
}();
</script>
这也使您无需指定 SVG sprite 的 URLxlink:href
<svg>
<use xmlns:xlink="http://www.w3.org/1999/xlink" xlink:href="#heart"></use>
</svg>