如何强制SVG图标缩放?

时间:2017-05-31 21:11:37

标签: html svg

以下是以蓝色DIV显示的SVG图标的简单示例。首先,CSS:

div.box {
    width: 72px;
    height: 72px;
    background-color: blue;
}

svg.icon {
    width: 72px;
    height: 72px;
    color: white;
    fill: currentColor;
}

...现在是HTML:

<body>
    <svg version="1.1" xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink">
        <defs>
            <g id="box-icon"><path d="M21 19V5c0-1.1-.9-2-2-2H5c-1.1 0-2 .9-2 2v14c0 1.1.9 2 2 2h14c1.1 0 2-.9 2-2zM8.5 13.5l2.5 3.01L14.5 12l4.5 6H5l3.5-4.5z"></path></g>
        </defs>
    </svg>


    <div class="box">
        <svg class="icon" viewBox="0 0 72 72"><use xlink:href="#box-icon"></use></svg>
    </div>
</body>

请参阅https://jsfiddle.net/b9fxvu7k/

请注意,DIV,图标和图标的视图框都大小为72像素。但是,无论我为DIV,图标和视图框指定的大小,浏览器都坚持将图标渲染为24像素。我需要SVG图标来扩展到其容器的大小。有谁看到缺少的东西?或者,我指定的SVG路径是否硬编码为24x24?

1 个答案:

答案 0 :(得分:2)

您可以使用g属性为transform添加比例因子,如下所示:

<g transform="scale(3)" ...

您也可以在CSS中获得相同的结果:

#button-icon {
  transform: scale(3);
}

但CSS方法显然不适用于IE。