最新公告
  • 欢迎您光临起源地模板网,本站秉承服务宗旨 履行“站长”责任,销售只是起点 服务永无止境!立即加入钻石VIP
  • 元素居中的N种方法

    正文概述 掘金(liupl)   2021-02-02   688

    前言

    刚参加工作时被面试官一连串居中问题虐的体无完肤得场景历历在目。“你是如何实现文本的居中的”“如果是多行文本呢”“块级元素的水平居中如何实现”“块级元素的垂直居中如何实现”。。。问到后面脑子里一团浆糊,本来知道的也不知道该如何回答了。居中是日常工作中不可避免要遇到的场景,面试中也是高频出现。这次的文章就围绕这些问题展开,希望能够帮助有和我当年一样疑惑的同学,在今后的工作和面试中再面对居中问题的时候可以游刃有余。

    行内元素居中

    文本垂直居中

    单行文本垂直居中

    单行文本的垂直居中是最简单的,设置line-height与盒子高度一样就可以。

    这里有一个误区,很多人设置单行文本居中的时候会同时设置heightline-height相同,其实大可不必设置height,只设置line-height就可以,这时候盒子的高度由line-height撑起来,与line-height完全相同。

    .center {
     	// 完全可以不设置高度
     	// height: 20px;
     	line-height: 20px;
    }
    

    多行文本垂直居中

    1.vertical-align

    元素居中的N种方法

    vertical-align可以指定行内元素的垂直对齐方式。

    这个方法需要多增加一个.center元素将需要居中的内容包裹起来。设置父元素的line-height为元素的高度,居中子元素.centerdisplayinline-block,使其拥有行内元素的特性,因为line-height的继承性,所以设置line-height: 20px;重置居中子元素的line-height,然后设置vertical-align: middle;在行框盒子内垂直居中对齐。

    <div class="box">
    	<div class="center">
    		虽然你们是扮演路人甲乙丙丁,但是一样是有生命、有灵魂的。
    	</div>
    </div>
    <style>
    .box {
    	background-color: orange;
    	line-height: 200px;
    	width: 300px;
    }
    .center {
    	background-color: green;
    	line-height: 20px;
    	display: inline-block;
    	vertical-align: middle;
    }
    </style>
    
    2.table-cell

    不同于行内元素设置利用vertial-align会使当前元素垂直居中对齐,table-cell元素设置vertial-align会让它的子元素垂直居中对齐,就算子元素是块级元素也会垂直对齐,所以想要实现块级元素的垂直居中也可以使用这个方法。

    .box {
           height: 200px;
           display: table-cell;
           vertical-align: middle;
    }
    

    行内元素水平居中

    text-align控制子行内元素的水平对齐方式,这个非常简单直接设置text-align:center就可以。

    .center {
           text-align: center;
    }
    

    块级元素水平居中

    margin的值为auto可以占据对应方向的所有剩余空间,如果设置水平方向上两个方向的margin值都为auto,两个方向就会平分剩余空间,从而实现居中。

    那么为什么我们从来没有使用这个方法来实现垂直方向的居中呢?因为auto值起作用有一个前置条件,就是在对应的方向上如果不设置具体的长度,会自动铺满。很显然width是可以铺满父元素的,而height不可以。

    .center {
    	margin: 0 auto;
    }
    

    块级元素垂直居中

    那可不可以利用margin:auto;实现垂直方向的居中呢?当然可以,可以通过修改writing-mode改变块的流动,使块横向流动,此时height方向就会默认平铺撑满,设置margin:auto;就可以实现垂直方向的居中。但是这个方法有副作用,因为writing-mode属性的可继承性,会导致该元素下得所有子元素全部流方向全部变为横向。而且此时水平方向不能再使用此方法实现居中了。

    <div class="box">
        <div class="center"> 
            虽然你们是扮演路人甲乙丙丁,但是一样是有生命、有灵魂的。
        </div>
    </div>
    <style>
    .box {
    	background-color: orange;
    	height: 200px;
    	writing-mode: vertical-lr;;
    }
    .center {
    	background-color: green;
    	height: 50px;
    	margin: auto 0;
    }
    </style>
    

    那有没有可能使用这个特性实现垂直与水平方向都居中呢?也是可以得,我们继续往下看

    水平垂直居中

    1.position(居中元素宽高固定)

    设置父元素绝对定位,居中元素相对定位,toprightbottomleft的值都为0,此时如果不设置具体的宽高,居中元素就会在水平和垂直两个方向都铺满父元素。此时再给它设置具体宽高配合margin:auto;就可以实现绝对居中了。

    需要注意的是这个方法只能兼容IE8及以上浏览器,如果项目要兼容IE7可以使用下面这种方法

    .box {
    	position: relative;
    }
    .center {
    	position:absolute;
    	width: 200px;
    	height: 200px;
    	top:0;
    	bottom:0;
    	left:0;
    	right:0;
    	margin: auto;
    }
    

    2.vertacal-align

    首先实现居中元素在水平方向上的居中,设置居中元素的display值为inline-clock,使其拥有行内元素的特性。给外层的盒元素设置text-align: center;使居中元素在水平方向上居中。

    然后再实现在垂直方向上的居中,这个方法需要添加一个辅助元素,设置辅助元素height:100%;使当前行框盒子的高度撑满父元素,然后设置vertical-align: middle;使其在垂直方向上居中对齐。

    <div class="box">
        <div class="assist"></div>
        <div class="center"> 
            虽然你们是扮演路人甲乙丙丁,但是一样是有生命、有灵魂的。
        </div>
    </div>
    <style>
    .box {
        background-color: orange;
        height: 200px;
        width: 500px;
        text-align: center;
    }
    .center {
        background-color: green;
        width: 150px;
        display: inline-block;
        vertical-align: middle;
    }
    .assist {
        display: inline-block;
        height: 100%;
        vertical-align: middle;
    }
    </style>
    

    3.position配合margin

    这个方法适用与居中元素宽高已知的情况。设置父元素相对定位,居中元素绝对定位,lefttop值都为50%,lefttop的值分别相对于父元素的宽高计算,此时居中元素的左上顶点会位于父元素的正中央。然后再设置居中元素的margin-leftmargin-top为宽高的负一半,让居中元素在水平方向相对于自身宽度的50%向左偏移,在垂直方向向上偏移相对于自身高度的50%,就可以实现居中效果了。

    <div class="box">
        <div class="center"> 
            虽然你们是扮演路人甲乙丙丁,但是一样是有生命、有灵魂的。
        </div>
    </div>
    <style>
    .box {
        background-color: orange;
        height: 200px;
        width: 500px;
        position: relative;
    }
    .center {
        background-color: green;
        width: 150px;
        height: 50px;
        position:absolute;
        top:50%;
        left:50%;
        margin-left: -75px;
        margin-top: -25px;
    }
    </style>
    

    4.position配合transform

    第四种方法是使用position配合transform。这种方法跟上一个方法原理上基本相似,但使用场景增加了宽高不固定的元素。一样的先设置父元素相对定位,居中元素绝对定位,lefttop值都为50%。再设置居中元素transform: traslate(-50%, -50%);translate的百分比值是相对于自身去计算的,让居中元素在水平方向相对于自身宽度的50%向左偏移,在垂直方向向上偏移相对于自身高度的50%,就可以实现居中效果了。

    <div class="box">
        <div class="center"> 
            虽然你们是扮演路人甲乙丙丁,但是一样是有生命、有灵魂的。
        </div>
    </div>
    <style>
    .box {
        background-color: orange;
        height: 200px;
        width: 500px;
        position: relative;
    }
    .center {
        background-color: green;
        width: 150px;
        position:absolute;
        top:50%;
        left:50%;
        transform: traslate(-50%, -50%);
    }
    </style>
    

    5.flex

    如果不需要考虑兼容IE9及以前的浏览器,flex布局是最推荐的方式。

    设置父元素为flex容器,主轴、交叉轴对齐方式都为居中对。关于flex的相关知识可以参考阮大神的博客,介绍的非常详细。

    .box {
        display: flex;
        align-items: center;
        justify-content: center;
    }
    

    起源地下载网 » 元素居中的N种方法

    常见问题FAQ

    免费下载或者VIP会员专享资源能否直接商用?
    本站所有资源版权均属于原作者所有,这里所提供资源均只能用于参考学习用,请勿直接商用。若由于商用引起版权纠纷,一切责任均由使用者承担。更多说明请参考 VIP介绍。
    提示下载完但解压或打开不了?
    最常见的情况是下载不完整: 可对比下载完压缩包的与网盘上的容量,若小于网盘提示的容量则是这个原因。这是浏览器下载的bug,建议用百度网盘软件或迅雷下载。若排除这种情况,可在对应资源底部留言,或 联络我们.。
    找不到素材资源介绍文章里的示例图片?
    对于PPT,KEY,Mockups,APP,网页模版等类型的素材,文章内用于介绍的图片通常并不包含在对应可供下载素材包内。这些相关商业图片需另外购买,且本站不负责(也没有办法)找到出处。 同样地一些字体文件也是这种情况,但部分素材会在素材包内有一份字体下载链接清单。
    模板不会安装或需要功能定制以及二次开发?
    请QQ联系我们

    发表评论

    还没有评论,快来抢沙发吧!

    如需帝国cms功能定制以及二次开发请联系我们

    联系作者

    请选择支付方式

    ×
    迅虎支付宝
    迅虎微信
    支付宝当面付
    余额支付
    ×
    微信扫码支付 0 元