我有一个大约 10 个项目的菜单。每个项目都有自己的图标。这个图标是一个 SVG 文件。
例如:
<li class="active">
<a href="/home">
<svg version="1.1" id="svg-menu-home"
xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink"
x="0px" y="0px" width="31px" height="31px" viewBox="-8 -8 31 31"
overflow="visible" enable-background="new -8 -8 31 31" xml:space="preserve">
<mask maskUnits="userSpaceOnUse" x="0" y="0" width="15" height="15" id="maskTop">
<polygon fill="#FFFFFF" points="12,6.036 2,6.036 2,14.036 6,14.036 6,9.036 8,9.036 8,14.036 12,14.036"/>
<polygon fill="#FFFFFF" points="7,0.036 0,7.036 14,7.036"/>
</mask>
<rect mask="url(#maskTop)" fill="#939598" width="15" height="15"/>
</svg>
<span>Home</span>
</a>
</li>
当用户与菜单项交互时,我可以为其分配一个类等(悬停、选择、活动)。
将整个源代码内联似乎是我可以使用 CSS 更改 SVG 的唯一方法,例如:
<style>
li.active svg polygon {
fill: red;
}
</style>
问题是:
- 内联大量 SVG 文件会使代码不可读,并且
- 如果您在其他地方引用 SVG,维护它并不容易。
我更愿意像使用 IMG ( ) 那样引用文件src<img src="x.jpg"/>
并避免依赖于 Javascript 的解决方案。
然而,我所看到的所有方式都不允许 SVG 元素的 CSS 样式(或需要 JS)。
有什么想法/解决方法吗?