CSS——把“可以动的盒子”更优雅地展示:② “居中”盒子

栏目: CSS · 发布时间: 5年前

内容简介:前言:让“盒子”居中,在实际工作中可以说是随时都会用到。方法很多,我们在都理解的基础上用起来才能有的放矢、得心应手。html
本文推荐 PC 端阅读~

本文版权归 “公众号 | 前端一万小时” 所有,未经授权,请勿转载!
复制代码
CSS——把“可以动的盒子”更优雅地展示:② “居中”盒子
css_13
复制代码
CSS——把“可以动的盒子”更优雅地展示:② “居中”盒子
1. 如何让块级元素水平居中?如何让行内元素水平居中?如何让 inline-block 元素水平居中?
2. 垂直上下居中的办法?
复制代码

前言:让“盒子”居中,在实际工作中可以说是随时都会用到。方法很多,我们在都理解的基础上用起来才能有的放矢、得心应手。

1 水平居中

1.1 在父元素上设置 text-align: center; 使文字/图片水平居中

.container {
  text-align: center;
}
复制代码

1.2 margin

.container {
  width: 80%;
  margin: 0 auto;
}
复制代码

2 垂直居中

2.1 居中 vs 不居中

:link:源码及效果展示

html

<div class="ct">
    <p>Hello,Oli的前端一万小时</p>
    <p>Hello,Oli的前端一万小时</p>
  </div>
复制代码

css

.ct {
  padding: 40px 0;
/*直接上下 padding 相等。整个容器的高度由内容高度撑开,
我们大部分页面都是这样的。*/

  text-align: center;
  background: #eee;
}
复制代码
CSS——把“可以动的盒子”更优雅地展示:② “居中”盒子

2.2 绝对定位实现“弹窗”居中

打开一个页面出现一个弹出框,那这个弹出框在页面垂直居中。这个弹出框可能下边还有东西,那这个弹出框很明显就是绝对定位了。因为,如果他不是绝对定位,他怎么去覆盖其他元素呢!

但由于用户的屏幕有大有小,但我都要让这个弹出框居中,怎样办?

:link:源码及效果展示

html

<body>
  <div class="dialog">
    <div class="header">我是标题</div>
    <div class="content">我是内容</div>
  </div>
</body>
复制代码

css

html,body {
  height: 100%;
}

/*:rocket:注释:one:*/
.dialog {
  position: absolute;
  left: 50%;
  top: 50%;
/* 由于用户的屏幕有大有小,那我都要让这个弹出框居中,怎样办?*/
/*left: 50% 表示 left 的值是它宽度的一半,所以它的这个“左上角”在
水平位置上是居中的;
   top: 50% 表示这个“左上角”在他的顶部(从上到下)是居于 50% ,即这个“左上
角”在页面上居中。*/


/*:rocket:注释:two:*/
  margin-left: -200px;
  margin-top: -150px;
/*但我们并不是需要这个“左上角”居中,而上想让“中心”居中,因此我们用了“负 margin”:
  margin-left: -200px; 表示让“左上角”再移动盒子“宽度”的一半;
  margin-top: -150px;  表示让“左上角”再移动盒子“高度”的一半。
  请看注释:one:的图!
*/


/*:question:但以上的移动都是基于盒子“宽高”在一定的前提下,
那如果“宽高”没有固定,那怎么实现居中呢?*/
/*答:
  transform: translate(-50%, -50%);

这个属性就是相对于自身“宽高”来做偏移,那这个时候,
我不管里边的内容是多少,它整个都是居中的。他对“宽高”就没有限制了。
这种方式是最好的,在 IE9 以上都可以用的。
请看注释:two:的图!
*/


  width: 400px;
  height: 300px;
  box-shadow: 0px 0px 3px #000;
}

.dialog .header{
  padding: 10px;
  background: #000;
  color: #fff;
}
.dialog .content{
  padding: 10px;
}
复制代码
  • 注释:one::

    CSS——把“可以动的盒子”更优雅地展示:② “居中”盒子
  • 注释:two::

    CSS——把“可以动的盒子”更优雅地展示:② “居中”盒子
    CSS——把“可以动的盒子”更优雅地展示:② “居中”盒子

2.3 伪元素实现居中

:link:源码及效果展示

html

<body>
  <div class="box">
    <img src="https://ws4.sinaimg.cn/large/006tNc79gy1g208frkqkhj30sk0kytk5.jpg" alt="">
  </div>
</body>
复制代码

css

.box{
  width: 300px;
  height: 200px;
  border: 1px solid ;
  text-align: center;
/*这个属性可以实现“水平”居中。*/

}

.box::before{
/*用伪元素选择器来实现“垂直”居中。*/

  content: '';
  display: inline-block;
  height: 100%;
/*使这个伪元素的高度等于盒子的高度,撑满父容器。*/

  vertical-align: middle;
}

.box img {
  vertical-align: middle;
  width: 150px;
}
复制代码
CSS——把“可以动的盒子”更优雅地展示:② “居中”盒子

2.4 table-cell 实现居中

:link:源码及效果展示

html

<body>
  <div class="box">
    <img src="https://ws4.sinaimg.cn/large/006tNc79gy1g208frkqkhj30sk0kytk5.jpg" alt="">
  </div>
</body>
复制代码

css

.box{
  width: 300px;
  height: 200px;
  border: 1px solid ;

  display: table-cell;
  vertical-align: middle;
/* vertical-align: middle 在表格元素中实现居中效果很明显。
但这里 display: table-cell; 后,就不是一个块级元素了,
如果不加宽度,那么宽度就会自动收缩!*/

  text-align: center;
}
复制代码
CSS——把“可以动的盒子”更优雅地展示:② “居中”盒子

2.5 display: flex; 实现居中

:link:源码及效果展示

html

<div class="space">
  <div class="earth"></div>
</div>
复制代码

css

.space {
  width: 100vw;
  height: 100vh;  
  /* 设置宽高以显示居中效果 */

  display: flex; 
   /* 弹性布局 */

  align-items: center; 
   /*告诉里边的盒子垂直方向上应该:垂直居中 */

  justify-content: center;  
  /*告诉里边的盒子水平方向上应该:水平居中 */
}

body {
  margin: 0;
  background: rgba(0, 0, 0, .95);
}

.earth::after {
  content: ':earth_asia:';
/*注意这个“地球”看着像个图片,但他实际上是一个文字。*/

  font-size: 85px;
}
复制代码

后记:下一篇我们讲“布局”,其实很多知识我们这连着的几篇文章都涉及到了,下一篇我们就做一个总结,看看我们实际工作中都有哪些常用的“布局”方式。

加油!


以上所述就是小编给大家介绍的《CSS——把“可以动的盒子”更优雅地展示:② “居中”盒子》,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对 码农网 的支持!

查看所有标签

猜你喜欢:

本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们

算法设计手册

算法设计手册

斯基恩纳 / 清华大学出版社 / 2009-9 / 69.00元

《算法设计手册(第2版)》是算法设计畅销书的最新版本,是设计实用且高效算法的最全面指导书。《算法设计手册(第2版)》揭密了算法的设计与分析,以简单易懂的写作风格,介绍了各种算法技术,着重强调了算法分析,全书包括两大部分,“技术”部分介绍了设计和分析计算机算法的各种方法,“资源”部分给出了大量的参考资源,以及算法实现的各种资源,此外,在作者的个人网址http://www.CS.sunysb.edu/......一起来看看 《算法设计手册》 这本书的介绍吧!

XML 在线格式化
XML 在线格式化

在线 XML 格式化压缩工具

Markdown 在线编辑器
Markdown 在线编辑器

Markdown 在线编辑器

HEX HSV 转换工具
HEX HSV 转换工具

HEX HSV 互换工具