前端HTML元素居中的几种方式及原理

HTML元素居中的10种方式

1、text-aligin:center
	text-aligin属性 是没有浮动的情况下,可以先将要居中的块级元素设为inline/inline-block,
然后在其父元素上加上属性text-align:center;
如果要居中的块级元素直接是内联元素(span、img、a等),直接在其父级元素上加上属性text-align:center;
2、绝对定位+偏移(已知道宽高,需计算偏移值)

优点:兼容性好。
缺点:必须知道元素的宽高。

.box1 {
    position: relative;
    width: 250px;
    height: 250px;
}
.box1 img {
    width: 200px;
    height: 140px;
    position: absolute;
    left: 50%;
    top: 50%;
    margin-left: -100px;
    margin-top: -70px;
}
3、margin:0 auto

**使用 margin:0 auto 这个属性的前提是居中的元素必须是块级元素,如果是内联元素,需要添加属性display:block,元素不浮动。

4、绝对定位(四个方向都是0)+margin:auto

**优点:不需要知道元素的宽高,而且浏览器的兼容性好。

.box2{
    position: relative;
    width: 250px;
    height: 250px;
}

.box2 img {
    position: absolute;
    left: 0;
    top: 0;
    right: 0;
    bottom: 0;
    margin: auto;
}
5、绝对定位+CSS3属性transform:translate()

**优点:不需要知道元素的宽度和高度,在移动端用的比较多,因为移动端对css3新属性的兼容性比较好。
**缺点:兼容性不好,只支持IE9+的浏览器。

div {
    position: relative;
    width: 250px;
    height: 250px;
}

div img {
    position: absolute;
    left: 50%;
    top: 50%;
  <!--设置元素的相对于自身的偏移度为负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%);
}
6、弹性布局display:flex

Flexbox布局最适合应用程序的组件和小规模布局,而 Gird 布局则适用于较大规模的布局。

设为Flex布局以后,子元素的float、clear和vertical-align属性将失效。

使用flex居中不需要知道元素本身宽高以及元素的属性。

div {
    width: 250px;
    height: 250px;
    display: flex;
    justify-content: center;/*水平居中*/
    align-items: center;/*垂直居中*/
}
7、display:table
HTML部分:
<div class="table">
    <div class="table-cell">
        近几年随着 jQuery、Ext 以及 CSS3 的发展,
        以 Bootstrap 为代表的前端开发框架如雨后春笋般挤入视野,
        可谓应接不暇。不论是桌面浏览器端还是移动端都涌现出很多优秀的框架,
        极大丰富了开发素材,也方便了大家的开发。
    </div>
</div>

CSS部分:
.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;
}

1、display: table;使块状元素成为一个块级表格;
2、display: table-cell;子元素设置成表格单元格;
3、vertical-align: middle;使表格内容居中显示,即可实现垂直居中的效果;

提示一下:
1.table-cell不感知margin,在父元素上设置table-row等属性,也会使其不感知height。
2.设置float或position会对默认布局造成破坏,可以考虑为之增加一个父div定义float等属性。
效果显示:
在这里插入图片描述

8、JQuery方法实现
	jquery实现 水平和垂直居中 的原理是通过jquery设置div的css,获取div的左,上的边距偏移量,
	边距偏移量的算法就是用页面窗口的宽度减去该div的宽度,得到的值再除以2即左偏移量,右偏移量算法相同。
	注意div的css设置要在resize()方法中完成,就是每次改变窗口大小是,都要执行设置div的css。

**优点:不需要知道div 的具体宽度和高度,直接用jquery就可以实现水平和垂直居中,并且兼容各种浏览器。这个方法在很多的弹出层效果中应用。

 $(function(){
          $(window).resize(function(){
            $('.mydiv').css({
              position:'absolute',
              left:($(window).width()-$('.mydiv').outerWidth())/2,
              top:($(window).height()-$('.mydiv').outerHeight())/2
            });
          });
      })
9、绝对定位+calc();(需要知道元素的宽高)
.div {
    position: relative;
    width: 250px;
    height: 250px;
}

.div img {
    width: 200px;
    height: 140px;
    position: absolute;
    left: calc(50% - 100px);
    top: calc(50% - 70px);
}

用于动态计算长度值。
需要注意的是,运算符前后都需要保留一个空格,例如:width: calc(100% - 10px)。
任何长度值都可以使用calc()函数进行计算。
calc()函数支持 “+”, “-”, “*”, “/” 运算。
calc()函数使用标准的数学运算优先级规则。

10、Bootstrap前端框架方法居中
Bootstrap3居中方法
文本居中   class=“text-center”
图片居中   class=“center-block”
其他元素 水平居中 利用bootstrap列偏移
<div class="col-lg-4 col-offset-4"></div>
Bootstrap4居中 class=“m-auto”
上面的居中方法是使整个元素居中,下面就来介绍下是元素内部居中的方法:
bootstrap3 如何让div内部垂直居中:

Bootstrap的栅格系统使用的是float:left的浮动方式,vertical-align属性不起作用,
故把内部div的float属性清除,添加display属性,如下:
.middle {
   float: none;
   display: inline-block;
   vertical-align: middle;
}

Bootstrap4 如何让div内部垂直居中:
给元素高度
.login-center {
 height: 100vh;
}
应用.align-items-center可以使元素垂直居中:

<divclass="row align-items-center justify-content-center login-center"></div>
同理,应用justify-content-center可以使元素水平居中。

在这里插入图片描述

本章参考来源:https://www.cnblogs.com/hellocd/p/10437651.html
希望对大家有帮助!加油!加油!加油!

  • 1
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值