元素水平垂直居中的方式

元素分为行内元素和块级元素,行内元素有1种方式设置元素垂直居中;块级元素有4种方式设置元素垂直居中。

Posted in HTML / CSS onMarch 31, 2021

行内元素

  1. 通过为父元素设置text-align、line-height属性实现元素垂直居中
.box{
	width:500px;
	height:100px;
	border:1px solid #333;
	line-height:100px;
	text-align:center;
}
<div class="box">
	<span>content</span>
</div>

块级元素

  1. 通过设置子元素的绝对定位和margin属性实现元素垂直居中(减去自身宽度高度的一半)
.box{
    width: 500px;
    height: 500px;
    border: 1px solid #333;
    position: relative;
}
.box div{
    width: 100px;
    height: 100px;
    border: 1px solid #333;
    position: absolute;
    left: 50%;
    top: 50%;
    margin-left: -50px;
    margin-top: -50px;
}
<div class="box">
	<div></div>
</div>
  1. 通过设置父元素flex弹性布局的方式实现元素垂直居中(项目在主轴上的对齐方式为居中,项目在交叉轴上对齐方式为居中)
.box{
    width: 500px;
    height: 500px;
    border: 1px solid #333;
    display: flex;
    justify-content: center;
    align-items: center;
}
.box div{
     width: 100px;
     height: 100px;
     border: 1px solid #333;
}
<div class="box">
        <div></div>
</div>
  1. 通过设置子元素的绝对定位和transform属性实现元素垂直居中(往x轴、y轴分别移动自身宽度和高度的50%)
.box{
    width: 500px;
    height: 500px;
    border: 1px solid #333;
    position: relative;
}
.box div{
    width: 100px;
    height: 100px;
    border: 1px solid #333;
    position: absolute;
    left: 50%;
    top: 50%;
    transform: translate(-50%,-50%);
}
<div class="box">
	<div></div>
</div>
  1. 通过设置子元素的绝对定位和margin属性实现元素垂直居中(不存在兼容性问题,自适应宽高)
    原理
    设置margin:auto分配左右的剩余空间,所以元素可以水平居中;设置绝对定位,此时margin-top、margin-bottom从默认为0变成auto,设置top、right、bottom、left为0将找到父元素的位置(给浏览器重新分配一个边界框),填充其父元素的所有可用空间,margin垂直方向有了可分配的空间,所以此时元素可以垂直居中。
.box{
    width: 500px;
    height: 500px;
    border: 1px solid #333;
    position: relative;
}
.box div{
     width: 100px;
     height: 100px;
     border: 1px solid #333;
     position: absolute;
     top: 0;
     right: 0;
     bottom: 0;
     left: 0;
     margin: auto;
}
<div class="box">
	<div></div>
</div>
HTML / CSS 相关文章推荐
HTML5如何适配 iPhone IOS 底部黑条
Mar 09 HTML / CSS
css3.0 图形构成实例练习二
Mar 19 HTML / CSS
CSS实现限制字数功能当对象内文本溢出时显示省略标记
Aug 20 HTML / CSS
一款纯css3实现的漂亮的404页面的实例教程
Nov 27 HTML / CSS
CSS3 box-shadow属性实例详解
Jun 19 HTML / CSS
使用CSS3实现字体颜色渐变的实现
Aug 10 HTML / CSS
HTML5之SVG 2D入门12—SVG DOM及DOM操作介绍
Jan 30 HTML / CSS
html5 input属性使用示例
Jun 28 HTML / CSS
html5 利用canvas实现超级玛丽简单动画
Sep 06 HTML / CSS
详解基于canvas的视频遮罩插件
Jan 04 HTML / CSS
HTML5自定义mp3播放器源码
Jan 06 HTML / CSS
详解盒子端CSS动画性能提升
May 24 HTML / CSS
简单介绍 http请求响应参数、无连接无状态、MIME、状态码、端口、telnet、curl
简单实现一个手持弹幕功能+文字抖动特效
HTML基础-标签分类(闭合标签,空标签,块级元素,行内元素,行级块元素,可替换元素)
Mar 31 #HTML / CSS
Web前端:CSS最强总结 附详细代码
血轮眼轮回眼特效 html+css
css3 filter属性的使用简介
Mar 31 #HTML / CSS
使用canvas实现雪花飘动效果的示例代码
You might like
php随机输出名人名言的代码
2012/10/07 PHP
PHP冒泡算法详解(递归实现)
2014/11/10 PHP
php安装swoole扩展的方法
2015/03/19 PHP
PHP中的数组处理函数实例总结
2016/01/09 PHP
javascript 页面只自动刷新一次
2009/07/10 Javascript
推荐20家国外的脚本下载网站
2011/04/28 Javascript
判断是否安装flash player及当前版本的JS代码
2013/08/08 Javascript
JavaScript中变量声明有var和没var的区别示例介绍
2014/09/15 Javascript
原生Ajax 和jQuery Ajax的区别示例分析
2014/12/17 Javascript
JavaScript实现模仿桌面窗口的方法
2015/07/18 Javascript
PassWord输入框代码分享
2016/06/07 Javascript
js 创建对象 经典模式全面了解
2016/08/16 Javascript
最实用的jQuery分页插件
2016/10/09 Javascript
jQuery extend()详解及简单实例
2017/05/06 jQuery
jQuery remove()过滤被删除的元素(推荐)
2017/07/18 jQuery
vue iview实现动态路由和权限验证功能
2018/04/17 Javascript
javascript实现图片轮播代码
2019/07/09 Javascript
element的el-table中记录滚动条位置的示例代码
2019/11/06 Javascript
vue 动态添加class,三个以上的条件做判断方式
2020/11/02 Javascript
python数据结构之二叉树的统计与转换实例
2014/04/29 Python
一步步教你用Python实现2048小游戏
2017/01/19 Python
Python基于identicon库创建类似Github上用的头像功能
2017/09/25 Python
python实现对指定输入的字符串逆序输出的6种方法
2018/04/26 Python
python对象与json相互转换的方法
2019/05/07 Python
python中for循环把字符串或者字典添加到列表的方法
2019/07/20 Python
pytorch+lstm实现的pos示例
2020/01/14 Python
移动web模拟客户端实现多方框输入密码效果【附代码】
2016/03/25 HTML / CSS
美国特价机票专家:Airfarewatchdog
2018/01/24 全球购物
业务部经理岗位职责
2014/01/04 职场文书
中秋节主持词
2014/04/02 职场文书
园艺专业毕业生求职信
2014/09/02 职场文书
财政局党的群众路线教育实践活动整改方案
2014/09/21 职场文书
房屋维修协议书范本
2014/09/25 职场文书
如何用python绘制雷达图
2021/04/24 Python
《艾尔登法环》1.03.3补丁上线 碎星伤害调整
2022/04/06 其他游戏
vscode内网访问服务器的方法
2022/06/28 Servers