html - 如何将未指定宽度的 div 居中?

标签 html css twitter-bootstrap

这是我的 HTML 代码:

<!DOCTYPE html>
<html lang="en">
    <head><link href="test.css" rel="stylesheet"></head>
    <body>
        <div class="outer">
            <div class="inner">
                <img src="test.png">
            </div>
        </div>
    </body>
</html>

这是 CSS:

.outer {
    position: fixed;
    top: 0; right: 0; bottom: 0; left: 0;
}

.inner {
    width: auto;
    margin: auto;
}

.inner > img {
    width: auto;
    max-width: 100%;
}

这是我在 Bootstrap 的 modal.js 中用于在单击缩略图后显示图像的代码的简化。

我想要的是以响应方式使图像以视口(viewport)为中心 - 也就是说,图像以其真实尺寸显示,除非视口(viewport)小于其中一个尺寸,在这种情况下,图像应相应地调整大小。

outer div 往往具有视口(viewport)的精确尺寸 - 这很好用。

图像被赋予 width: auto; max-width: 100%; 对视口(viewport)的宽度非常敏感,但对视口(viewport)的高度没有反应。添加 max-height: 100%; 没有任何作用。

不幸的是,inner div 紧贴视口(viewport)的左侧,除非指定了特定的宽度

如果我将 display: table 添加到 .inner,则 div 居中,但不再响应视口(viewport)宽度的变化。

那么,我如何让 inner div 居中并响应视口(viewport)的宽度和高度,而不会裁剪或改变图像的纵横比或将其拉伸(stretch)超出图片的原始尺寸?

仅使用 CSS 和 HTML(以及 Bootstrap)是不可能的,还是需要一些自定义 JS?我对 JS 的了解还不够多,无法自信地自己编写代码,这就是为什么我希望有一些可爱的 CSS 技巧可以允许这种以视口(viewport)大小为条件的矛盾行为。

标记 Twitter 的 Bootstrap,因为我将在 Bootstrap 上下文中使用它,因此欢迎任何使用 Bootstraps JS 插件的解决方案。

编辑:为了更清楚,我需要将 inner 居中,而不仅仅是 inner 中的图像。

最佳答案

像这样更改代码

.outer {
        position: fixed;
        top: 0; right: 0; bottom: 0; left: 0;
        text-align:center;
    }

http://jsbin.com/puyabore/1/edit

关于html - 如何将未指定宽度的 div 居中?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/24176531/

相关文章:

javascript - jQuery仅隐藏单击的特定表行onclick事件

javascript - node.js 表单处理更新和删除

html - 如何对齐链接 HTML/CSS

javascript - 我可以修改我的按钮 onclick 脚本吗

javascript - Bootstrap 3 轮播无法正确加载/显示

javascript onDOMContentLoaded 不触发

html - 如何阻止溢出干扰 z-index?

javascript - 使用 html CSS 和 javascript 创建轮播的问题

html - 缩略图图像未水平对齐

mysql - 从模式更新 mysql 记录时遇到问题