如何向内联 svg 添加额外的外部 space?
How to add extra outer space to inline svg?
我有一个透明 fill
和深色 stroke
的内联 svg。当它悬停时,我想 fill
用深色。
问题是,当我增加 stroke-width
以使描边更明显时,描边超出了元素的宽度框,如下面的屏幕截图所示。
那么如何给 svg 元素一个额外的 space 来让笔触变长呢?
svg {
width: 10rem;
fill: transparent;
stroke: #222;
stroke-width: 30;
}
svg:hover {
fill: #222;
}
<svg
viewBox="0 -28 512.00002 512"
xmlns="http://www.w3.org/2000/svg"
>
<path d="m471.382812 44.578125c-26.503906-28.746094-62.871093-44.578125-102.410156-44.578125-29.554687 0-56.621094 9.34375-80.449218 27.769531-12.023438 9.300781-22.917969 20.679688-32.523438 33.960938-9.601562-13.277344-20.5-24.660157-32.527344-33.960938-23.824218-18.425781-50.890625-27.769531-80.445312-27.769531-39.539063 0-75.910156 15.832031-102.414063 44.578125-26.1875 28.410156-40.613281 67.222656-40.613281 109.292969 0 43.300781 16.136719 82.9375 50.78125 124.742187 30.992188 37.394531 75.535156 75.355469 127.117188 119.3125 17.613281 15.011719 37.578124 32.027344 58.308593 50.152344 5.476563 4.796875 12.503907 7.4375 19.792969 7.4375 7.285156 0 14.316406-2.640625 19.785156-7.429687 20.730469-18.128907 40.707032-35.152344 58.328125-50.171876 51.574219-43.949218 96.117188-81.90625 127.109375-119.304687 34.644532-41.800781 50.777344-81.4375 50.777344-124.742187 0-42.066407-14.425781-80.878907-40.617188-109.289063zm0 0"/>
</svg>
调整viewBox
属性:
viewBox="-25 -53 562.00002 562"
为 25px
利润添加 space。
请注意,您必须将 top/left 坐标减少 25,将 bottom/right 坐标增加两倍,因为您的 width/height 必须满足 2 倍的边距宽度。
svg {
width: 10rem;
fill: transparent;
stroke: #222;
stroke-width: 30;
}
svg:hover {
fill: #222;
}
<svg
viewBox="-25 -53 562.00002 562"
xmlns="http://www.w3.org/2000/svg"
>
<path d="m471.382812 44.578125c-26.503906-28.746094-62.871093-44.578125-102.410156-44.578125-29.554687 0-56.621094 9.34375-80.449218 27.769531-12.023438 9.300781-22.917969 20.679688-32.523438 33.960938-9.601562-13.277344-20.5-24.660157-32.527344-33.960938-23.824218-18.425781-50.890625-27.769531-80.445312-27.769531-39.539063 0-75.910156 15.832031-102.414063 44.578125-26.1875 28.410156-40.613281 67.222656-40.613281 109.292969 0 43.300781 16.136719 82.9375 50.78125 124.742187 30.992188 37.394531 75.535156 75.355469 127.117188 119.3125 17.613281 15.011719 37.578124 32.027344 58.308593 50.152344 5.476563 4.796875 12.503907 7.4375 19.792969 7.4375 7.285156 0 14.316406-2.640625 19.785156-7.429687 20.730469-18.128907 40.707032-35.152344 58.328125-50.171876 51.574219-43.949218 96.117188-81.90625 127.109375-119.304687 34.644532-41.800781 50.777344-81.4375 50.777344-124.742187 0-42.066407-14.425781-80.878907-40.617188-109.289063zm0 0"/>
</svg>
我有一个透明 fill
和深色 stroke
的内联 svg。当它悬停时,我想 fill
用深色。
问题是,当我增加 stroke-width
以使描边更明显时,描边超出了元素的宽度框,如下面的屏幕截图所示。
那么如何给 svg 元素一个额外的 space 来让笔触变长呢?
svg {
width: 10rem;
fill: transparent;
stroke: #222;
stroke-width: 30;
}
svg:hover {
fill: #222;
}
<svg
viewBox="0 -28 512.00002 512"
xmlns="http://www.w3.org/2000/svg"
>
<path d="m471.382812 44.578125c-26.503906-28.746094-62.871093-44.578125-102.410156-44.578125-29.554687 0-56.621094 9.34375-80.449218 27.769531-12.023438 9.300781-22.917969 20.679688-32.523438 33.960938-9.601562-13.277344-20.5-24.660157-32.527344-33.960938-23.824218-18.425781-50.890625-27.769531-80.445312-27.769531-39.539063 0-75.910156 15.832031-102.414063 44.578125-26.1875 28.410156-40.613281 67.222656-40.613281 109.292969 0 43.300781 16.136719 82.9375 50.78125 124.742187 30.992188 37.394531 75.535156 75.355469 127.117188 119.3125 17.613281 15.011719 37.578124 32.027344 58.308593 50.152344 5.476563 4.796875 12.503907 7.4375 19.792969 7.4375 7.285156 0 14.316406-2.640625 19.785156-7.429687 20.730469-18.128907 40.707032-35.152344 58.328125-50.171876 51.574219-43.949218 96.117188-81.90625 127.109375-119.304687 34.644532-41.800781 50.777344-81.4375 50.777344-124.742187 0-42.066407-14.425781-80.878907-40.617188-109.289063zm0 0"/>
</svg>
调整viewBox
属性:
viewBox="-25 -53 562.00002 562"
为 25px
利润添加 space。
请注意,您必须将 top/left 坐标减少 25,将 bottom/right 坐标增加两倍,因为您的 width/height 必须满足 2 倍的边距宽度。
svg {
width: 10rem;
fill: transparent;
stroke: #222;
stroke-width: 30;
}
svg:hover {
fill: #222;
}
<svg
viewBox="-25 -53 562.00002 562"
xmlns="http://www.w3.org/2000/svg"
>
<path d="m471.382812 44.578125c-26.503906-28.746094-62.871093-44.578125-102.410156-44.578125-29.554687 0-56.621094 9.34375-80.449218 27.769531-12.023438 9.300781-22.917969 20.679688-32.523438 33.960938-9.601562-13.277344-20.5-24.660157-32.527344-33.960938-23.824218-18.425781-50.890625-27.769531-80.445312-27.769531-39.539063 0-75.910156 15.832031-102.414063 44.578125-26.1875 28.410156-40.613281 67.222656-40.613281 109.292969 0 43.300781 16.136719 82.9375 50.78125 124.742187 30.992188 37.394531 75.535156 75.355469 127.117188 119.3125 17.613281 15.011719 37.578124 32.027344 58.308593 50.152344 5.476563 4.796875 12.503907 7.4375 19.792969 7.4375 7.285156 0 14.316406-2.640625 19.785156-7.429687 20.730469-18.128907 40.707032-35.152344 58.328125-50.171876 51.574219-43.949218 96.117188-81.90625 127.109375-119.304687 34.644532-41.800781 50.777344-81.4375 50.777344-124.742187 0-42.066407-14.425781-80.878907-40.617188-109.289063zm0 0"/>
</svg>