我有一个SVG,我试图在一个div居中。div的宽度为900px。SVG的宽度为400px。SVG的左边距和右边距设置为auto。不起作用,它就像左距为0一样(默认值)。

有人知道误差是多少吗?


当前回答

只需将容器视为flex,并将svg项以flex属性居中即可:

<div classname='icon'>
  <svg>.....</svg>
</div>

.icon{
  display:flex;
  align-items:center;
  justify-content:center;
 }

其他回答

确保你的CSS如下:

margin: 0 auto;

即使您说您已经将左和右设置为auto,您可能会放置一个错误。当然我们不知道,因为你没有给我们看任何代码。

把这两行放到style.css中 在指定的div类中。

   display: block;
   margin: auto;

然后尝试运行它,您将能够看到SVG现在在中心对齐。

读了上面的内容,svg默认是内联的,我只是在div中添加了以下内容:

<div style="text-align:center;">

这招对我很管用。

纯粹主义者可能不喜欢它(这是一张图片,不是文本),但在我看来,HTML和CSS在居中位置上搞砸了,所以我认为这是合理的。

SVG默认是内联的。

添加display: block到它,然后margin: auto将按预期工作。

或者根据你的布局,你可能想保持SVG内联,并在父元素上设置text-align: center。

作为另一种选择,您可以使用flex或网格布局将SVG居中在父元素上。

Flexbox是另一种方法:添加

.container { 显示:flex; justify-content:中心; }

并将.container类添加到包含svg的div中。