前提:元素没有浮动,而且是内联元素(如:span、img、b)。如果是块级元素,要把块级元素设置成display:inline-block;或display:inline;
前提:元素必须是块级元素,如果是内联元素,必须设置为display:block;
div { position: relative; width: 250px; height: 250px; } div img { width: 200px; height: 140px; position: absolute; left: 50%; top: 50%; margin-left: -100px; margin-top: -70px; }
div { position: relative; width: 250px; height: 250px; } div 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新属性的兼容性比较好。
div { width: 250px; height: 250px; display: flex; justify-content: center;/*水平居中*/ align-items: center;/*垂直居中*/ }
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); }
合使用display:table-cell和vertical-align、text-align,使父元素内的所有行内元素水平垂直居中(内部div设置display:inline-block即可)。这在子元素不确定宽高和数量时,特别实用!
div { display: table-cell; width: 250px; height: 250px; text-align: center; vertical-align: middle; float: none; } div img { display: inline-block; }
原文:https://www.cnblogs.com/hellocd/p/10437651.html