内联元素居中方案

水平居中设置:

  1. 行内元素 设置 text-align:center;

  2. Flex布局 设置display:flex;justify-content:center;(灵活运用)

垂直居中设置:

  1. 父元素高度确定的单行文本(内联元素) 设置 height = line-height;
  2. 父元素高度确定的多行文本(内联元素) a:插入 table (插入方法和水平居中一样),然后设置 vertical-align:middle; b:先设置 display:table-cell 再设置 vertical-align:middle;

    块级元素居中方案

    水平居中设置:

  3. 定宽块状元素 设置 左右 margin 值为 auto;

  4. 不定宽块状元素 a:在元素外加入 table 标签(完整的,包括 table、tbody、tr、td),该元素写在 td 内,然后设置 margin 的值为 auto; b:给该元素设置 display:inine 方法; c:父元素设置 position:relative 和 left:50%,子元素设置 position:relative 和 left:50%;

垂直居中设置:

  • 1.使用position:absolute(fixed),设置left、top、margin-left、margin-top的属性;

    1. .box{
    2. position:absolute;/*或fixed*/
    3. top:50%;
    4. left:50%;
    5. margin-top:-100px;
    6. margin-left:-200px;
    7. }
    • 2.利用position:fixed(absolute)属性,margin:auto这个必须不要忘记了;
  1. .box{
  2. position: absolute;或fixed
  3. top:0;
  4. right:0;
  5. bottom:0;
  6. left:0;
  7. margin: auto;
  8. }
  • 3.利用display:table-cell属性使内容垂直居中,这个方法在多行文字居中的时候用的比较多;

HTML代码:

  1. <div class="box">
  2. <span>多行文字,此处居中设置</span>
  3. </div>

CSS代码:

  1. .box{
  2. display:table-cell;
  3. vertical-align:middle;
  4. text-align:center;
  5. width:100px;
  6. height:120px;
  7. background:purple;
  8. }
  9. .box span{
  10. display: inline-block;
  11. vertical-align: middle;
  12. }
  • 4.使用css3的新属性transform:translate(x,y)属性;
  1. .box{
  2. position: absolute;
  3. top:50%;
  4. left:50%;
  5. transform: translate(-50%,-50%);
  6. -webkit-transform:translate(-50%,-50%);
  7. -moz-transform:translate(-50%,-50%);
  8. -ms-transform:translate(-50%,-50%);
  9. }
  • 5.最高大上的一种,使用before,after伪元素;

HTML代码:

  1. <div class='box'>
  2. <div class='content'>
  3. 垂直居中
  4. </div>
  5. </div>

CSS代码:

  1. .box{
  2. position:fixed;
  3. display:block;
  4. background:rgba(0,0,0,.5);
  5. }
  6. .box:before{
  7. content:'';
  8. display:inline-block;
  9. vertical-align:middle;
  10. height:100%;
  11. }
  12. .box:after{
  13. content:'';
  14. display:inline-block;
  15. vertical-align:middle;
  16. height:100%;
  17. }
  18. .box .content{
  19. width:60px;
  20. height:60px;
  21. line-height:60px;
  22. color:red;
  23. }
  • 6.Flex布局;
  1. .box{
  2. display: -webkit-box;
  3. display: -webkit-flex;
  4. display: -moz-box;
  5. display: -moz-flex;
  6. display: -ms-flexbox;
  7. display: flex;
  8. 水平居中
  9. -webkit-box-align: center;
  10. -moz-box-align: center;
  11. -ms-flex-pack:center;
  12. -webkit-justify-content: center;
  13. -moz-justify-content: center;
  14. justify-content: center;
  15. 垂直居中
  16. -webkit-box-pack: center;
  17. -moz-box-pack: center;
  18. -ms-flex-align:center;
  19. -webkit-align-items: center;
  20. -moz-align-items: center;
  21. align-items: center;
  22. }

CSS的垂直居中和水平居中总结的更多相关文章

  1. CSS垂直居中和水平居中

    前言 CSS居中一直是一个比较敏感的话题,为了以后开发的方便,楼主觉得确实需要总结一下了,总的来说,居中问题分为垂直居中和水平居中,实际上水平居中是很简单的,但垂直居中的方式和方法就千奇百怪了. 内联 ...

  2. css居中问题:水平居中、垂直居中

    亲们支持我的新博客哦==>原文地址 ) 本篇文章所有演示代码下载==>github/calamus0427 css水平垂直居中是面试时候遇到最多的问题,我总结一下大部分解决方案 水平居中: ...

  3. HTML/CSS:图片居中(水平居中和垂直居中)

    css图片居中(水平居中和垂直居中) css图片居中分css图片水平居中和垂直居中两种情况,有时候还需要图片同时水平垂直居中, 下面分几种居中情况分别介绍: css图片水平居中 1.利用margin: ...

  4. css/css3 未知元素宽高,垂直居中和水平居中

    未知元素的宽高情况下  垂直居中和水平居中 第一种 flex盒布局 (推荐) /*弹性盒模型*/ /*主轴居中对齐*/ /*侧轴居中对齐*/ .ele{ display:flex; justify-c ...

  5. 通过设置CSS属性让DIV水平居中

    通过设置CSS属性让DIV水平居中 ---------------------- <html> <head> <title></title> <m ...

  6. 五种方法让CSS实现垂直居中

    利用 CSS 来实现对象的垂直居中有许多不同的方法,比较难的是选择那个正确的方法.我下面说明一下我看到的好的方法和怎么来创建一个好的居中网站. 使用 CSS 实现垂直居中并不容易.有些方法在一些浏览器 ...

  7. CSS实现垂直居中的5种方法

    利用 CSS 来实现对象的垂直居中有许多不同的方法,比较难的是选择那个正确的方法.我下面说明一下我看到的好的方法和怎么来创建一个好的居中网站. 使用 CSS 实现垂直居中并不容易.有些方法在一些浏览器 ...

  8. [转]-CSS 元素垂直居中的6种方法

    原文地址:http://blog.zhourunsheng.com/2012/03/css-%E5%85%83%E7%B4%A0%E5%9E%82%E7%9B%B4%E5%B1%85%E4%B8%AD ...

  9. CSS水平垂直居中总结

    行内元素水平居中 把行内元素包裹在块级父元素中,且父元素中的css设置text-align:center; <!DOCTYPE html> <html> <head> ...

随机推荐

  1. 怎么在Vue中使用Base64格式的背景

    问题发生于一次mock数据,生成了base64格式的东西,因为编码包在一个变量中,不知道怎么直接在 :style 中引入. 解答1:格式background-image: url(此处是我们mock生 ...

  2. C++11随机数发生器

    前言 一直知道所谓的"随机数"都是伪随机,事实上也是满足某种规则生成的.有些程序测试时通常需要一个随机数源,但在新标准出现之前,C++都是依赖简单的C库函数rand来生成随机数的. ...

  3. 基于svn+ssh:访问svn的部署以及客户端配置

    1.安装ssh sudo apt-get install ssh 2.安装subversion sudo apt-get install subversion 3.为参与项目开发的成员建立用户帐户 s ...

  4. php与MySQL与echart综合使用

    http://www.yinghualuowu.com/php/echart.html 创建table sex 有name num             <?php ini_set('disp ...

  5. DEDE修改注册邮箱时一起修改UCenter中用户邮箱的问题

    最近在做一个项目,就是在账号安全栏目中加一个修改邮箱并验证的功能,这个功能并不复杂,可以参照用户注册时的邮箱验证来实现. 就是当用户更改邮箱并提交之后,发一封包含一个链接的邮件到用户的新邮箱中,当用户 ...

  6. 基于FCM的消息推送功能

    需求背景 我方项目需要支持客户端消息推送,iOS终端可以借由苹果本身的apns很方便的实现,但是对于Android来说,必须集成第三方的SDK来处理.考虑到项目需要以及成本,我们选择使用谷歌的FCM框 ...

  7. Quartz 定时器,同时运用多个定时器

    效果:每天执行两个定时器,两个定时器不相关联.jar版本Quartz 2.2.3 Java工程结构图  jar 包下载: 链接: https://pan.baidu.com/s/1-7dh620k9P ...

  8. hibernate课程 初探单表映射2-2 hibernate常用配置

    1 hibernate.cfg.xml常用配置: show_sql 控制台打印sql format_sql 控制台将sql排版 hbm2ddl.auto: create 删除表结构,重新建表并插值 u ...

  9. linux 跳过登陆修改用户密码

      2017-02-11 20:41 6人阅读 评论(0) 收藏 编辑 删除  分类: Linux 版权声明:本文为博主原创文章,未经博主允许不得转载. Linux 系统默认的是有0 1 2  3   ...

  10. 2016多校训练3_1007(hdu5758 Explorer Bo)

    #include <functional> #include <algorithm> #include <iostream> #include <iterat ...