CSS 居中方法总结

简介:

文字水平和垂直居中

     <div class="textAlignCenter">
        <span>居中</span>
      </div>
     .textAlignCenter{
          text-align: center;
        }

使用text-align可以实现块级元素内文本和图片水平居中,对于文字来说,可以设置line-height 来实现单行文字的垂直居中,但是对于多行文字来说,效果不好。所以可以通过table布局来实现多行文字垂直居中。

     <div class="textAlignCenter">
        <span>居中</span>
      </div>
     .textAlignCenter{
          text-align: center;
          display:table;
       }
      span{
        display:table-cell;
        vertical-align: middle;
      }

实现图片的水平垂直居中

1.通过vertical-align:middle实现垂直居中

  .textAlignCenter{
    width: 400px;
    height: 300px;
    text-align: center; //文字和图片的水平居中
    display: table-cell; //主要是这个元素和vertical-align 属性实现水平居中
    vertical-align: middle;
  }
  img{
    width:100px;
    height:100px;  
  }
    <div class="textAlignCenter">
        <img src="./img/1.pic.jpg"></img>
  </div>
  
  1. 采用背景法
<div class="img_bg"></div>
.img_bg{
    width: 400px;
    height: 300px;
    background: url(img.jpg) no-repeat center center;
}

水平且垂直居中

  1. 宽高固定的元素的水平垂直居中
    设定父级容器为相对定位的容器,设定子元素绝对定位的位置为顶部和左部50%,最后使用负向 margin 实现水平和垂直居中,margin 的值为宽高的一半。
.parent { position: relative; }
 .child { 
    width: 100px;
    height: 50px; 
    position: absolute; 
    top: 50%; 
    left: 50%; 
    margin: -50px 0 0 -25px;
}
  1. 宽高不固定元素水平垂直居中

如果无法获取确定的宽高,同样需要设定父级容器为相对定位的容器,但是需要使用 CSS3 属性 transform: translate(-50%, -50%) 实现水平垂直居中,但是该属性有兼容性问题,如下:
Internet Explorer 10、Firefox、Opera 支持 transform 属性。
Internet Explorer 9 支持替代的 -ms-transform 属性(仅适用于 2D 转换)。
Safari 和 Chrome 支持替代的 -webkit-transform 属性(3D 和 2D 转换)。
Opera 只支持 2D 转换。

.parent { position: relative; }
 .child { 
   position: absolute; 
   top: 50%; 
   left: 50%; 
    transform: translate(-50%, -50%); 
  }

如果不考虑浏览器兼容性问题,可以考虑使用flex属性,
使用 flexbox 实现水平和垂直居中,只需使用两条居中属性即可:

.parent {
  display: flex;
  justify-content: center;
  align-items: center;
}
目录
相关文章
|
1月前
|
前端开发
CSS水平居中与垂直居中的方法
CSS水平居中与垂直居中的方法
|
1月前
|
前端开发
CSS画三角形(三种方法)
CSS画三角形(三种方法)
|
1月前
|
前端开发 计算机视觉 开发者
利用CSS改变图片颜色的100种方法!
利用CSS改变图片颜色的100种方法!
35 1
|
2月前
|
前端开发 JavaScript 开发者
CSS隐藏元素的N种方法,你知道哪一种最适合你?
欢迎来到前端入门之旅!这个专栏是为那些对Web开发感兴趣、刚刚开始学习前端的读者们打造的。无论你是初学者还是有一些基础的开发者,我们都会在这里为你提供一个系统而又亲切的学习平台。我们以问答形式更新,为大家呈现精选的前端知识点和最佳实践。通过深入浅出的解释概念,并提供实际案例和练习,让你逐步建立起一个扎实的基础。无论是HTML、CSS、JavaScript还是最新的前端框架和工具,我们都将为你提供丰富的内容和实用技巧,帮助你更好地理解并运用前端开发中的各种技术。
|
9天前
|
前端开发
css中几种隐藏元素的方法
css中几种隐藏元素的方法
11 0
|
10天前
|
JavaScript 前端开发 iOS开发
js实用方法记录-动态加载css/js
js实用方法记录-动态加载css/js
16 0
|
13天前
|
Web App开发 前端开发 开发者
css检查方法
【4月更文挑战第13天】css检查方法
14 2
|
13天前
|
XML 前端开发 开发者
css的常用方法
【4月更文挑战第13天】css的常用方法
13 3
|
4月前
|
缓存 前端开发 JavaScript
CSS提高性能的方法有哪些?
CSS提高性能的方法有哪些?
86 1
|
1月前
|
前端开发
CSS清除浮动的八种方法
CSS清除浮动的八种方法