html - 如何在其中垂直和水平居中 div 的内容?

标签 html twitter-bootstrap css

我有一个投资组合类型 3 分栏布局。每个投资组合元素都是一个包含元素名称和一些简短内容的 div。首先显示元素名称,当我将鼠标悬停在 div 上时,div 翻转,然后显示简介。

当我将鼠标悬停在 div 上时,简报从左上角溢出。我希望元素名称和简介都放在 div 的正中央。以下是代码片段。

.flip-container {
  perspective: 1000;
  margin-right: 30px;
  background-color: red;
  margin-bottom: 20px;
}
/* flip the pane when hovered */

.flip-container:hover .flipper,
.flip-container.hover .flipper {
  transform: rotateY(180deg);
}
.flip-container,
.front,
.back {
  width: 360px;
  height: 320px;
}
/* flip speed goes here */

.flipper {
  transition: 0.6s;
  transform-style: preserve-3d;
  position: relative;
}
/* hide back of pane during swap */

.front,
.back {
  backface-visibility: hidden;
  position: absolute;
  text-align: center;
  /*top: 0;
	left: 0;*/
}
/* front pane, placed above back */

.front {
  z-index: 2;
  /* for firefox 31 */
  transform: rotateY(0deg);
}
/* back, initially hidden pane */

.back {
  transform: rotateY(180deg);
}
<div class="row">
  <div class="flip-container col-md-4 portfolio-item" ontouchstart="this.classList.toggle('hover');">
    <div class="flipper">
      <div class="front">
        <!-- front content -->
        <h3>
                        <a href="#">Project Name</a>
                      </h3>
      </div>
      <div class="back">
        <!-- back content -->
        <p>Lorem ipsum dolor sit amet, consectetur adipiscing elit. Nam viverra euismod odio, gravida pellentesque urna varius vitae.</p>
      </div>
    </div>
  </div>
  <div class="flip-container col-md-4 portfolio-item" ontouchstart="this.classList.toggle('hover');">
    <div class="flipper">
      <div class="front">
        <!-- front content -->
        <h3>
                      <a href="#">Project Name</a>
                    </h3>
      </div>
      <div class="back">
        <!-- back content -->
        <p>Lorem ipsum dolor sit amet, consectetur adipiscing elit. Nam viverra euismod odio, gravida pellentesque urna varius vitae.</p>
      </div>
    </div>
  </div>

最佳答案

您可以使用 flexbox为了这。将以下样式添加到您的 .front.back div

CSS:

.front,
.back {
  backface-visibility: hidden;
  position: absolute;
  text-align: center;
  display: flex;
  align-items: center;
  justify-content: center;
}

这是一个working fiddle .

关于html - 如何在其中垂直和水平居中 div 的内容?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/35018507/

相关文章:

jquery - 单击以展开文本

HTML、CSS 将 div 放在相对元素的左侧而不是右侧

javascript - 将值设置为输入字段 onchange 从其他输入字段

javascript - 类型错误 : Cannot read property 'top' of undefined jQuery

javascript - 带推特 Bootstrap 的日期范围选择器

javascript - 单击 html bootstrap 时禁用图像

javascript - 在 contenteditable 中查找光标目标元素 id

jquery - 下拉菜单打开时选择选项的文本颜色可见吗?

jquery - 选项卡未聚焦于链接

html - 填充背景图像悬停创建额外的不需要的空间