transform:translate(-50%,-50%)实现水平垂直居中

Posted knuzy

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了transform:translate(-50%,-50%)实现水平垂直居中相关的知识,希望对你有一定的参考价值。

translate()函数是css3的新特性.在不知道自身宽高的情况下,可以利用它来进行水平垂直居中.。

当使用:top: 50%;left: 50%;, 是以左上角为原点,故不处于中心位置

 translate(-50%,-50%) 作用是,往上(x轴),左(y轴)移动自身长宽的 50%,以使其居于中心位置。

 

与负margin-left和margin-top实现居中不同的是,margin-left必须知道自身的宽高,而translate可以在不知道宽高的情况下进行居中,tranlate()函数中的百分比是相对于自身宽高的百分比,所以能进行居中。

 1 .content {
 2     padding:10px;
 3     background:green;
 4     color:#fff;
 5     position:absolute;
 6     top:50%;
 7     left:50%;
 8     border-radius: 5px;
 9     -webkit-transform: translate(-50%,-50%);
10     -moz-transform: translate(-50%,-50%);
11     transform:translate(-50%,-50%);
12 }

 

以上是关于transform:translate(-50%,-50%)实现水平垂直居中的主要内容,如果未能解决你的问题,请参考以下文章

单击时包裹在 Transform.translate 中的 TextField 不聚焦

Unity中的物体移动-Transform.Translate

html5 横向滚动,无滚动条(transform:translate)

为啥 CSS transform,translate 会改变旋转元素的旋转?

css3中transition 过渡效果如何只对transform:scale 起作用,对其它像transform: translate不起作用!

搞清animation/transtion/transform/translate