如何在不知道图像宽度或高度的情况下将图像垂直和水平居中在浮动div上?
良好的浏览器不等式,它需要在 IE 8 及以上版本上有效; 如何在不知道图像宽度或高度的情况下将图像置于浮动 div 上?
该图像在语义上是相关的,因此它不能是背景; html:
<div class="logo-organization-home">
<img src="images/logoOrganization1.png" alt="logo organization 1"/>
</div>
和 css:
.logo-organization-home {
float:left;
background-color: #fafaed;
border: 4px solid #f7f4ee;
width: 18%;
}
我尝试过 display:table-cell;没有成功; 我尝试过使用一定的填充来居中对齐文本:没有成功;
尝试失败: http://cssdesk.com/pQnRG
谢谢
Good browsers out of equation, it needs to be valid on IE 8 and sup;
How to center image on a floated div without knowing image width or height ?
The image is semantically relevant so, it cannot be a background;
The html:
<div class="logo-organization-home">
<img src="images/logoOrganization1.png" alt="logo organization 1"/>
</div>
And the css:
.logo-organization-home {
float:left;
background-color: #fafaed;
border: 4px solid #f7f4ee;
width: 18%;
}
I've tried display:table-cell; no success;
I've tried text-align center with a certain padding: no success;
Failed try:
http://cssdesk.com/pQnRG
Thanks
如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。
data:image/s3,"s3://crabby-images/d5906/d59060df4059a6cc364216c4d63ceec29ef7fe66" alt="扫码二维码加入Web技术交流群"
绑定邮箱获取回复消息
由于您还没有绑定你的真实邮箱,如果其他用户或者作者回复了您的评论,将不能在第一时间通知您!
发布评论
评论(3)
要水平居中,请使用: 'text-align:center' for .logo-organization-home
To center horizontaly, use: 'text-align:center' for .logo-organization-home
如果包含元素有宽度,则可以使用以下内容:
If the containing element has a width, you can use the following:
关于水平居中,您链接到此处的示例: http://cssdesk.com/pQnRG 无法正常工作因为div的宽度小于图像的宽度。例如,如果将宽度增加到 40%,您将看到图像将正确居中,即使包含的 div 有内边距。
关于垂直居中,在 IE8 上,display:table-cell“需要 !DOCTYPE.IE9”。 http://www.w3schools.com/cssref/pr_class_display.asp 或者,尽管不道德,您可以直接使用表格/行/单元格作为附加容器:
以及 HTML:
Concerning horizontal centering, the example that you linked to here: http://cssdesk.com/pQnRG does not work properly since the width of the div is smaller than the width of the image. If you increase the width to 40% for example, you'll see that the image will be centered correctly, even when the containing div has a padding.
Concerning vertical centering, display:table-cell "requires a !DOCTYPE. IE9" on IE8. http://www.w3schools.com/cssref/pr_class_display.asp Alternatively, although unethical, you can use a table/row/cell directly as an additional container:
And the HTML: