不定宽高垂直居中分析

  昨天做移动项目是,遇到这样一个案例,如图,图片容器随着视口宽度进行自由拉伸扩张,图片不定宽高,垂直居中:

  当时做这个布局的时候,我一直想到用display:table-cell通过vertical-align:middle,来实现居中,可以当我在同一个节点用position:absolute,会导致此居中问题失效。

  最后想到的解决方案,案例如下,不定宽高垂直居中:

<!DOCTYPE HTML>
<html lang="en-US">
<head>
    <meta charset="UTF-8">
    <title></title>
    <meta name="viewport" content="width=device-width, initial-scale=1, minimum-scale=1.0, maximum-scale=1.0">

    <style type="text/css">
        p{margin:0;padding:0}
        .wrap,.wrap1{
            width:30%;
            padding-top:30%;
            background:#eee;
            position:relative;
        }
        .wrap p,.wrap1 p{
            position:absolute;
            top:0;
            left:0;
            width:100%;
            height:100%;
        }
        .wrap p img{
            max-width:100%;
            max-height:100%;
            position:absolute;
            top:50%;
            left:50%;
            -webkit-transform-origin:50% 50%;
            -webkit-transform:translate3d(-50%,-50%,0);
        }
        .wrap1 p{text-align:center;font-size:0;}
        .wrap1 p:after{
            width:0;
            height:100%;
            display:inline-block;
            vertical-align:middle;
            content:"";
        }
        .wrap1 p img{
            display:inline-block;
            max-width:100%;
            max-height:100%;
            vertical-align:middle;
            margin:0 auto;
        }
    </style>
</head>
<body>
    <h2>第一种方案</h2>
    <div class="wrap">
        <p>
            <img src="img/download.jpg" alt="" />
        </p>
    </div>
    <h1>111</h1>
    <div class="wrap">
        <p>
            <img src="img/download1.jpg" alt="" />
        </p>
    </div>

    <h2>第二种方案</h2>
    <div class="wrap1">
        <p>
            <img src="img/download.jpg" alt="" />
        </p>
    </div>
    <h1>111</h1>
    <div class="wrap1">
        <p>
            <img src="img/download1.jpg" alt="" />
        </p>
    </div>    

    <div id="demo">
    <p>水平垂直居中的随意内容</p>
</div>
</body>
</html>

  

  下面我们将分别介绍三种垂直居中的解决方案:

  已咀嚼一下以前的几个老知识点:

  1.水平居中知识点

text-align:center

  对于水平居中可能不需要太多的介绍,所有主流浏览器均支持 text-align 属性,只需要取值 center 即可;

  2.vertical-align知识点

vertical-align适用于 inline level, inline-block level 及 table-cells 元素上

  所有主流浏览器均支持 vertical-align 属性,所以使用该属性来实现垂直居中是一个不错的想法;

  一、利用display:table-cell;vertical-align:middle;进行不定高度,垂直居中 例子demo

<div id="demo">
	<p>水平垂直居中的随意内容</p>
</div>
#demo{
	display:table;
	width:500px;
	margin:10px auto;
	background:#eee;
}
#demo p{
	display:table-cell;
	height:100px;
	vertical-align:middle;
}

   既然table能实现,自然也就会想到将 display 设置为table系value来实现。当然,该方案是有局限性的,因为IE8以下的浏览器不支持 display 的table系value,所以你只能在IE8及以上浏览器以及非IE浏览器下才能看到效果;

  二、利用display:table-cell;vertical-align:middle;进行不定高度,垂直居中  例子DEMO

<div id="demo">
    <p>水平垂直居中的随意内容</p>
</div>
#demo{
    height:100px;
    text-align:center;
}
#demo:after{
    display:inline-block;
    width:0;
    height:100%;
    vertical-align:middle;
    content:‘‘;
}
#demo p{
    display:inline-block;
    vertical-align:middle;
}

  这里有一点需要非常注意:参照以上代码,如果我们的内容容器p的宽度为100%时,就会导致#demo:after被挤出不在一行,这个是由于inline元素间隔导致的,可以设置font:0消除,如果为了保持全兼容,可以不用伪类,使用span标签去替代。

  完美解决方案:例子demo

<div id="demo">
    <p>这是一个终极实现的水平垂直居中实例</p>
    <!--[if lt IE 8]><span></span><![endif]-->
</div>
#demo{
    height:100px;
    text-align:center;
    font-size:0;  //注意这里是去除文字间隔,放在内容宽度为100%时挤出换行
}
#demo:after,#demo span{
    display:inline-block;
    *display:inline;
    *zoom:1;
    width:0;
    height:100%;
    vertical-align:middle;
}
#demo:after{
    content:‘‘;
}
#demo p{
    display:inline-block;
    *display:inline;
    *zoom:1;
    vertical-align:middle;
    font-size:16px;
}

  三、利用translate3d(-50%,-50%,0)实现垂直居中,只支持高版本

    <style type="text/css">
        .main{width:600px;height:600px;position:relative}
        .box{position:absolute;top:50%;left:50%;-webkit-transform-origin:50% 50%;-webkit-transform:translate3d(-50%,-50%,0)}
    //原理有点跟 top:50%;left:50%;margin:-height/2 0 0 -width/2类似,这种是要知道高度,但是这个不需要
    </style>

    <div class="main">
        <div class="box">555666</div>
    </div>

  四、利用两级嵌套,两次left,top实现居中

<style type="text/css">
html,body{width: 100%; height: 100%; margin: 0; padding: 0;}
.wrp{position: fixed; width: 100%; height: 100%; left: 0; top: 0; background-color: rgba(0,0,0,.5);}
.box{position: absolute; left: 50%; top: 50%;}
.box2{position: relative; left: -50%; top: -50%; background-color: #f60000; color: #fff; padding: 10px;}
</style>

<div class="wrp">
	<div class="box">
		<div class="box2">
			sssssfdsfd
		</div>
	</div>
</div>

  利用两个不定宽高的div相嵌。外围的div用absolute定位,left:50%,top:50%。这样外围的div的左上角处于水平垂直居中状 态。内部的div使用relative定位,这样可以利用自身的宽高撑开外围的div,再用left:-50%,top:-50%;(用margin- left,margin-top也可以,就是利用取值的是参照外围div的宽高的原理)实现内部div的几何中心与外围的div左上角重合。这样实现了垂 直水平剧中。这个原理有点像使用translate(-50%,-50%)来实现水平垂直居中,不过我用的是css1.0的代码,所以兼容性很好 IE6.0~IE11 chrome,firefox都可以

  资料参考:

    未知尺寸元素水平垂直居  http://demo.doyoe.com/css/alignment/

时间: 2024-08-01 04:28:14

不定宽高垂直居中分析的相关文章

不定宽高的水平垂直居中

不定宽高的水平垂直居中的两种方法: 1/ .mybox{position:absolute;top:50%;left:50%;z-index:3;-webkit-translate(-50%,50%);background:#fff;} 2/.parent{justify-content:center;align-items:center;display:-webkit-flex;}

CSS + DIV 居中写法(不定宽高)

最新写法:CSS3,不兼容IE8- position: fixed; top: 50%; left: 50%; width: 50%; max-width: 630px; min-width: 320px; height: auto; z-index: 2000; visibility: hidden; -webkit-backface-visibility: hidden; -moz-backface-visibility: hidden; backface-visibility: hidde

图片 + 未知宽高 + 垂直居中

图片 + 未知宽高 + 垂直居中 第一种: table-cell / inline-block + vertical-align条件: 容器宽高受图片默认宽高影响html结构: <div> <img src="./image.jpg" > </div> css代码: div { display: inline-block; /*display: table-cell;*/ padding: 10px; border: 2px solid #aaa;

网页元素居中攻略记_(5)未知元素宽高垂直居中

题外话 以前,我们要自适应全局居中,需要借助JS或者JQ来实现,现在有了CSS3就可以省去好多功夫了,为什么这么说!! 请看比较: 传统的绝对居中 #container{ position:abosolute; top:50%; left:50%; margin-left:-包含块宽度的一半(如 -300px ); margin-top: -包含块高度的一半; } 这种是实现了包含块的绝对居中,但是有一个问题,就是宽高度无法自适应(需固定宽高)-比如动态增加数据的时候,用这个就不大合适了-.这时

transform的妙用---实现div不定宽高垂直水平居中

transform的兼容性 transform的兼容性还是比较乐观的.IE9以下不兼容,IE9支持代替的-ms-transform属性不过只支持2D转换. 谷歌和Safari支持代替的-webkit-transform属性.IE9以上.火狐和欧朋是兼容的. transform 属性向元素应用 2D 或 3D 转换.该属性允许我们对元素进行旋转.缩放.移动或倾斜. 在此,可妙用其移动的属性. 遇见div不定宽和高垂直水平居中的问题.记得以前都是用js去实现.现在可以用 transform进行实现.

web前端入门到实战:CSS不定宽高的垂直水平居中,9 种方式总汇

垂直居中,在 CSS 中是一个老生常谈的问题,面试的时候也会时常被提及.所以,今天我们就来聊聊 9 种不同的居中方法. 有常见的 flex.transform.absolute 等等.也有 CSS3 的网格布局.还有伪元素的方法,是的,你没有看错,::after 和 ::before 也可以实现居中. 1.flex 大家的第一反应,可能就是 flex 了.因为它的写法够简单直观,兼容性也没什么问题.是手机端居中方式的首选. <div class="wrapper flex-center&q

不定宽高水平垂直居中

1 <div id="demo"> 2 <p>这是一个终极实现的水平垂直居中实例</p> 3 <!--[if lt IE 8]><span></span><![endif]--> 4 </div> 5 #demo{ 6 height:100px; 7 text-align:center; 8 font-size:0; //注意这里是去除文字间隔,放在内容宽度为100%时挤出换行 9 } 10

CSS3 不定宽高水平垂直居中

display: flex; justify-content: center; // 子元素水平居中 align-items: center; // 子元素垂直居中 [在父元素上添加上面3句,即可实现子元素水平垂直居中] 原文地址:https://www.cnblogs.com/queende7/p/8666544.html

不定宽高盒子水平垂直居中的写法

1. width: 1200px;     height: 600px;     position: absolute;     left: 50%;     top: 50%;     transform: translate(-50%,-50%); 2. width: 1200px;     height: 600px;     position: absolute;     left: 50%;     top: 50%;     margin:-300px 0 0 -600px: