这个是没有浮动的情况下,我们可以先将要居中的块级元素设为inline/inline-block,然后在其父元素上加上属性text-align:center;即可。如果要居中的块级元素直接是内联元素(span、img、a等),直接在其父级元素上加上属性text-align:center;即可;
前提:居中的元素必须是块级元素,如果是内联元素,需要添加属性display:block;而且元素不浮动。
.way {
position: relative;
width: 250px;
height: 250px;
}
.way img {
width: 200px;
height: 140px;
position: absolute;
left: 50%;
top: 50%;
margin-left: -100px;
margin-top: -70px;
}
兼容性好; 缺点:必须知道元素的宽高
.way4 {
position: relative;
width: 250px;
height: 250px;
}
.way4 img {
position: absolute;
left: 0;
top: 0;
right: 0;
bottom: 0;
margin: auto;
}
这种方法的好处是不需要知道元素的宽高,而且浏览器的兼容性好。
div {
position: relative;
width: 250px;
height: 250px;
}
div img {
position: absolute;
left: 50%;
top: 50%;
-webkit-transform: translate(-50%, -50%);
-moz-transform: translate(-50%, -50%);
-o-transform: translate(-50%, -50%);
-ms-transform: translate(-50%, -50%);
transform: translate(-50%, -50%);
}
该方法的优点是不需要知道元素的宽度和高度,在移动端用的比较多,因为移动端对css3新属性的兼容性比较好。
缺点:兼容性不好,只支持IE9+的浏览器
div {
width: 250px;
height: 250px;
display: flex;
justify-content: center;/*水平居中*/
align-items: center;/*垂直居中*/
}
实例:多行文本的垂直居中
主要实现代码:
<div class="table">
<div class="table-cell">
近几年随着 jQuery、Ext 以及 CSS3 的发展,以 Bootstrap 为代表的前端开发框架如雨后春笋般挤入视野,可谓应接不暇。不论是桌面浏览器端还是移动端都涌现出很多优秀的框架,极大丰富了开发素材,也方便了大家的开发。
div>
div>
.table{
width: 400px;
height: 400px;
padding: 20px;
border: 1px solid red;
margin: 40px auto;
display: table;
}
.table-cell{
display: table-cell;
text-align: center;
vertical-align: middle;
}
特别提醒
jquery实现水平和垂直剧中的原理是通过jquery设置div的css,获取div的左,上的边距偏移量,边距偏移量的算法就是用页面窗口的宽度减去该div的宽度,得到的值再除以2即左偏移量,右偏移量算法相同。注意div的css设置要在resize()方法中完成,就是每次改变窗口大小是,都要执行设置div的css,代码如下:
$(function(){
$(window).resize(function(){
$('.mydiv').css({
position:'absolute',
left:($(window).width()-$('.mydiv').outerWidth())/2,
top:($(window).height()-$('.mydiv').outerHeight())/2
});
});
})
此方法的好处就是不需要知道div 的具体宽度和高度,直接用jquery就可以实现水平和垂直居中,并且兼容各种浏览器。这个方法在很多的弹出层效果中应用。
.div {
position: relative;
width: 250px;
height: 250px;
}
.div img {
width: 200px;
height: 140px;
position: absolute;
left: calc(50% - 100px);
top: calc(50% - 70px);
}
Bootstrap3居中方法
Bootstrap4居中
上面的居中方法是使整个元素居中,下面就来介绍下是元素内部居中的方法
Bootstrap的栅格系统使用的是float:left的浮动方式,vertical-align属性不起作用,故把内部div的float属性清除,添加display属性,如下:
.middle {
float: none;
display: inline-block;
vertical-align: middle;
}
给元素高度
.login-center {
height: 100vh;
}
应用.align-items-center可以使元素垂直居中:
同理,应用justify-content-center可以使元素水平居中。
元素居中方法目前了解到的就只有这些,如有更好的方法欢迎大家评论,谢谢~