前端开发中,咱们常常须要对元素进行水平垂直居中。为此,小编特意总结了让元素居中的方法。
这个是没有浮动的状况下,咱们能够先将要居中的块级元素设为inline/inline-block,而后在其父元素上加上属性text-align:center;便可。若是要居中的块级元素直接是内联元素(span、img、a等),直接在其父级元素上加上属性text-align:center;便可;css
.way { border: 1px solid red; width: 250px; } .way img { max-width: 200px; } .way1 { text-align: center; font-size: 0px; //HTML图片之间,浏览器会产生默认的间距,父元素设置font-size:0px;能够很好地解决这个问题。 } <div class="way way1"> <img src="fj.jpg" alt=""> </div>
前提:居中的元素必须是块级元素,若是是内联元素,须要添加属性display:block;并且元素不浮动。前端
.way2 img { display: block; margin: 0 auto; } <div class="way way2"> <img src="fj.jpg" alt=""> </div>
前提:必须知道设置要居中元素的宽高jquery
.way3 { position: relative; width: 250px; height: 250px; } .way3 img { width: 200px; height: 140px; position: absolute; left: 50%; top: 50%; margin-left: -100px; margin-top: -70px; }
这种方法的好处是不须要知道元素的宽高,并且浏览器的兼容性好。css3
.way4 { position: relative; width: 250px; height: 250px; } .way4 img { position: absolute; left: 0; top: 0; right: 0; bottom: 0; margin: auto; }
该方法的优势是不须要知道元素的宽度和高度,在移动端用的比较多,由于移动端对css3新属性的兼容性比较好。web
.way5 { position: relative; width: 250px; height: 250px; } .way5 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%); }
.way6 { position: relative; width: 250px; height: 250px; } .way6 img { width: 200px; height: 140px; position: absolute; left: calc(50% - 100px); top: calc(50% - 70px); }
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就能够实现水平和垂直居中,而且兼容各类浏览器。这个方法在不少的弹出层效果中应用。浏览器
使用flex居中不须要知道元素自己宽高以及元素的属性。函数
.way7 { width: 250px; height: 250px; display: flex; justify-content: center;/*水平居中*/ align-items: center;/*垂直居中*/ }
组合使用display:table-cell和vertical-align、text-align,使父元素内的全部行内元素水平垂直居中(内部div设置display:inline-block便可)。这在子元素不肯定宽高和数量时,特别实用!布局
.way8 { display: table-cell; width: 250px; height: 250px; text-align: center; vertical-align: middle; float: none; } .way8 img { display: inline-block; }
特别提醒:flex