css居中的常用方法
2019-06-12 13:47
1026 查看
css居中的常用方法
相信很多程序员都对居中样式不陌生,特别是前端人员,估计天天调整样式。而居中样式是非常常见且重要的。
时一个属性就能搞定,有时则需要一定的技巧才能兼容到所有浏览器,利用css来实现对象的垂直居中有许多不同的方法,比较难的是应该选择哪种正确的方法。
1.margin:0 auto; 也就是将margin-left和margin-right属性设置为auto,从而达到水平居中的效果。
2.利用line-height设为height的一样即可
<div class="wrap">w3cschool</div> .wrap{ line-height: 200px;/*垂直居中关键*/ text-align:center; height: 200px; font-size: 36px; background-color: #ccc; }
3.padding填充
利用padding和background-clip配合实现div的水平垂直居中:
<div class="parent"> <div class="children"></div> </div>
通过background-clip设置为content-box,将背景裁剪到内容区外沿,再利用padding设为外div减去内div的差的一半,来实现:
.parent{ margin:0 auto; width:200px; height:200px; background-color:red; } .children { width: 100px; height: 100px; padding: 50px; background-color: black; background-clip:content-box;/*居中的关键*/
4.利用position:absolute搭配top,left 50%,再将margin设为负值也可以对div进行水平垂直居中,首先还是需要定义父子div:
<div class="parent"> <div class="children"></div> </div> .parent { position:relative; margin:0 auto; width:200px; height:200px; background-color:red; } .children { position:absolute; left:50%; top:50%; margin:-25px 0 0 -25px ; height:50px; width:50px; background-color: black; }
图片居中
一般的图片居中都是和text-align一样,将图片包装在一个div中,将该div的text-align设为center即可。
有一种特殊的方式,利用了一个图片进行占位,以让父容器获得高宽,从而让进行-50%偏移的图片能有一个参照容器作百分比计算。优点是可以不知道图片的大小,随便放张尺寸不超过父容器的图片上去都能做到居中。另外,兼容性好,IE6都是能顺利兼容的。代码如下:
<div class="parent"> <p> <img class="hidden-img" src="http://nec.netease.com/img/s/1.jpg" alt="" /> <img class="show-img" src="http://nec.netease.com/img/s/1.jpg" alt="" /></p> </div> .parent { position:relative; width:100%; height:200px; background:red; } p { position:absolute; top:50%; left:50%; } .hidden-img { visibility:hidden; } .show-img { position:absolute; right:50%; bottom:50%; }
2.transform居中
上面讲到的div居中的例子中,div的宽度都是固定的,然而实际项目中,有可能遇到不定宽的div,特别是响应式或者移动端的设计中,更加常见。所以下面介绍一种不需要定宽的div水平垂直居中方法
<div class="parent"> <div class="children"> <div class="children-inline">我是水平垂直居中噢!</div> </div> </div> .parent { float: left; width: 100%; height: 200px; background-color: red; } .children { float:left; position:relative; top:50%; left:50%; } .children-inline { position: relative; left: -50%; -webkit-transform : translate3d(0, -50%, 0); transform : translate3d(0, -50%, 0); background-color: black; color:white; }
相关文章推荐
- CSS实现垂直居中的常用方法
- CSS实现垂直居中的常用方法
- css 实现垂直居中的常用方法
- CSS实现垂直居中的常用方法 在前端开发过程中,盒子居中是常常用到的。其中 ,居中又可以分为水平居中和垂直居中。水平居中是比较容易的,直接设置元素的margin: 0 auto就可以实现。但是垂直
- CSS实现垂直居中的常用方法
- 最常用的居中方法css
- CSS实现垂直居中的常用方法
- CSS实现垂直居中的常用方法
- CSS实现垂直居中的常用方法
- CSS实现垂直居中的常用方法
- CSS居中的常用方法
- CSS实现垂直居中的常用方法
- css布局网页水平居中常用方法
- html/css实现居中的几个常用方法
- 如何实现CSS居中?–CSS居中常用方法
- 如何实现CSS居中?–CSS居中常用方法
- CSS实现垂直居中的常用方法
- CSS实现垂直居中的常用方法
- CSS实现垂直居中的常用方法
- CSS几种常用水平垂直居中的方法