1、水平居中

水平居中可分为行内元素水平居中块级元素水平居中

1.1 行内元素水平居中

这里行内元素是指文本text、图像img、按钮超链接等,只需给父元素设置text-align:center即可实现。

.center{
text-align:center;
}
<div class="center">水平居中</div>

1.2 块级元素水平居中

  • 定宽块级元素水平居中
    只需给需要居中的块级元素加margin:0 auto即可,但这里需要注意的是,这里块状元素的宽度width值一定要有

      .center{
    width:200px;
    margin:0 auto;
    border:1px solid red;
    }
    <div class="center">水平居中</div>
  • 不定宽块级元素水平居中
    不定宽,即块级元素宽度不固定
    方法1:设置table

    通过给要居中显示的元素,设置display:table,然后设置margin:0 auto来实现

      .center{
    display:table;
    margin:0 auto;
    border:1px solid red;
    }
    <div class="center">水平居中</div>

    方法2:设置inline-block(多个块状元素)
    子元素设置inline-block,同时父元素设置text-align:center

      .center{
    text-align:center;
    }
    .inlineblock-div{
    display:inline-block;
    }
    <div class="center">
    <div class="inlineblock-div">1</div>
    <div class="inlineblock-div">2</div>
    </div>

    方法3:设置flex布局
    只需把要处理的块状元素的父元素设置display:flex,justify-content:center;

      .center{
    display:flex;
    justify-content:center;
    }
    <div class="center">
    <div class="flex-div">1</div>
    <div class="flex-div">2</div>
    </div>

    方法4:position + 负margin;
    方法5:position + margin:auto;
    方法6:position + transform;

    注:这里方法4、5、6同下面垂直居中一样的道理,只不过需要把top/bottom改为left/right,在垂直居中部分会详细讲述。

2、垂直居中

2.1 单行文本垂直居中

  • 设置paddingtop=paddingbottom;或
  • 设置line-height=height;

2.2 多行文本垂直居中

通过设置父元素table,子元素table-cell和vertical-align
vertical-align:middle的意思是把元素放在父元素的中部

2.3 块级元素垂直居中

方法1:flex布局
在需要垂直居中的父元素上,设置display:flex和align-items:center
要求:父元素必须显示设置height值

显示效果:

方法2:利用position和top和负margin(需知宽高)
1、设置元素为absolute/relative/fixed
2、margin=负一半

效果如下:

方法3:利用position和top/bottom和margin:auto(注意不是margin:0 auto)
1、position:absolute/relative/fixed
2、top/bottom:0
3、margin:auto

效果如下:

方法4:利用position和top和transform
transform中translate偏移的百分比就是相对于元素自身的尺寸而言的。

效果如下:

注:

  • 上述的块级垂直居中方法,稍加改动,即可成为块级水平居中方法,如top/bottom换成left/right
  • transform方法,可用于未知元素大小的居中

3、水平垂直居中

方法1:绝对定位+margin:auto

    div{
width: 200px;
height: 200px;
background: green; position:absolute;
left:0;
top: 0;
bottom: 0;
right: 0;
margin: auto;
}

方法2:绝对定位+负margin

    div{
width:200px;
height: 200px;
background:green; position: absolute;
left:50%;
top:50%;
margin-left:-100px;
margin-top:-100px;
}

方法3:绝对定位+transform

    div{
width: 200px;
height: 200px;
background: green; position:absolute;
left:50%; /* 定位父级的50% */
top:50%;
transform: translate(-50%,-50%); /*自己的50% */
}

方法4:flex布局

   .box{
height:600px; display:flex;
justify-content:center; //子元素水平居中
align-items:center; //子元素垂直居中
/* aa只要三句话就可以实现不定宽高水平垂直居中。 */
}
.box>div{
background: green;
width: 200px;
height: 200px;
}

方法5:table-cell实现居中

  • 设置
    display:table-cell;
    text-align:center;
    vertical-align: middle;

最新文章

  1. apache2.2 虚拟主机配置
  2. UITableView添加静态背景.
  3. 关于jQuery表单校验的应用
  4. js 实现分割条
  5. python import 自己的包
  6. 【读书笔记】C Primer Plus ch.15位运算 示例程序15.1 整数转换成二进制字符串
  7. 洛谷 P1273 【有线电视网】
  8. PAT 2016 数据的交换输出
  9. Python中定义函数时参数有默认值的小陷阱
  10. Flask 5 模板1
  11. 迷你MVVM框架 avalonjs 0.84发布
  12. 【bzoj3730】震波 动态点分治+线段树
  13. CF910C
  14. 【转】JMeter远程测试
  15. 【2008nmj】GDA二元分类.docx
  16. 【BZOJ1820】[JSOI2010]Express Service 快递服务 暴力DP
  17. 《Cracking the Coding Interview》——第1章:数组和字符串——题目5
  18. 日常沟通的 3 种模式zz
  19. c和c++字符串分割
  20. 【CF766D】Mahmoud and a Dictionary(并查集)

热门文章

  1. [LC] 270. Closest Binary Search Tree Value
  2. js 判断元素的display是否为block或者none
  3. CentOS6与CentOS7的启动过程
  4. 忘记mysql root用户密码的解决办法(skip-grant-tables)
  5. Java发送邮箱
  6. OLED带来全新视觉体验
  7. 关于虚拟机VMware Tools安装中出现的无法自动安装VMCI驱动程序的问题
  8. 用缓冲技术OSCache 提高JSP应用的性能和稳定性
  9. 《自动化平台测试开发-Python测试开发实战》新书出版了
  10. Java并发 - (无锁)篇6