1 水平居中

首先讨论一下如何将一个元素进行水平居中。给定以下HTML代码。

<div class='box'>水平居中</div>

通过css实现div的水平居中。

.box{width:300px;height: 300px;margin: 0 auto;}

首选设置box的宽度和高度,然后设置box外边距margin就可以实现水平居中。实现的原理很简单,利用了盒模型来解决这个问题。

box的盒模型水平布局由以下7个属性相加组成。

  • margin-left
  • border-left
  • padding-left
  • width
  • padding-right
  • border-right
  • margin-right

假设浏览器的宽度是1080px,那么box的父元素的宽度也是1080px,box想在父元素容器里面实现水平居中,通过设置margin的左右边距就可以实现。但浏览器的宽度不是固定的,要想动态实现水平居中,那么就不能固定设置margin的值。

通过margin:0 auto就可以自动设置左右边距,其代表的意思是,上下外边距为0,左右外边距自动,auto就会自动折半给box设置外边距。

2 水平垂直居中

2.1 方法一

<div class='box'></div>

/* 设置top,bottom,left,right都为0,margin为auto */.box{width:200px;height:200px;background-color:#bra;position:absolute;top:0;bottom:0;left:0;right:0;margin:auto;}

2.2 方法二

<div class='box'></div>

/* 设置margin向负方向移动,移动的距离是box宽高的一半 */.box{width:200px;height:200px;background-color:#bra;position:absolute;left:'50%',right:'50%',margin: -100px -100px;}

2.3 方法三

<div class='box'></div>

/* 通过translate来平移实现,相比于上面哪种方法,可以实现自适应 */.box{width:200px;height:200px;background-color:#bra;position:absolute;left:'50%';right:'50%';transform:translate('50%','50%')}

2.4 方法四

<div class='box'><div class='box1'></div></div>

/* flex布局法,设置水平和垂直居中 */.box{dispaly:flex;align-items:center;justify-content:center;height:1000px;}.box1{width:100px;height:100px;background-color:pink;}

通过flex布局实现水平垂直居中要注意一个问题,前面几个例子都是一个div元素,而掌柜例子有两个div元素,使用需要将外面的div设置一个高度,这样垂直布局居中才会生效,否则就外面div的高度就是子div的高度,看不出来水平垂直居中的效果。

©著作权归作者所有:来自51CTO博客作者偉的原创作品,如需转载,请注明出处,否则将追究法律责任

更多相关文章

  1. 考考你的经济学水平,不服来战,学霸们
  2. 前端面试经典问题:CSS中居中的几种方式
  3. 【归纳】赶紧收藏css实现水平垂直居中的八种快速方法总结
  4. 1. 实例演示box-sizing属性; 2. 实例演示常用的元素居中方式
  5. 0324作业
  6. 传统定位和flex定位
  7. box-sizing功能。相对定位与绝对定位。绝对定位:块级居中。
  8. 0323作业
  9. 0323作业-CSS盒模型、CSS相对定位和绝对定位及块元素垂直居中

随机推荐

  1. android > 弹出复选框
  2. 【android 权限】
  3. android ndk 安装
  4. android在线API地址
  5. Android之HorizontalScrollView(一)
  6. android绘图网格线
  7. Android 驱动(5)---MTK 平台分区表
  8. Android 6.0 使用HttpClient的问题
  9. android jsonrpc 使用实例
  10. AllowBackup/FullBackupContent Problems