元素滚动和内容垂直居中同时存在,完美的 html 元素垂直居中的方法flex + margin: auto

假设有一个元素 div 作为父容器且宽高固定,里面的内容 content 在父容器中垂直/水平都居中,且当内容很多时,父元素滚动overflow: auto,content的内容要能够完全展示。

我之前在这篇文档提到了两个方法:

  1. 使用 flex + safe 关键字【不兼容safari】
  2. 三层 dom 结构

三层dom结构的代码如下:

html 复制代码
<template>
	<div class="outer-wrapper">
		<div class="inner-wrapper">
			<div class="content">真正的内容区域</div>
		</div>
	</div>
</template>
<style lang="scss" scoped>
.outer-wrapper {
	width: 100%; // 外层设置宽高
	height: 100%;
	border: 2px solid;
	display: flex;
	flex-direction: column;
	align-items: center; // 外层可以设置垂直和水平居中
	justify-content: center;
	padding: 20px;
	.inner-wrapper {
		border: 2px solid red;
		width: 80%; // 内层只能设置宽度,不能设置高度,高度让内容自动撑开,才能达到居中的效果
		display: flex;
		flex-direction: column;
		align-items: center; // 内层只能设置水平居中,不能设置垂直居中
		padding: 20px;
		overflow: auto; // 给内层设置overflow
		.content {
			width: 100%;
			height: 2000px;
			flex-shrink: 0;
			background: #ccc;
		}
	}
}
</style>

虽然这种方法可以实现功能,但是需要在父元素和 content 之间新包一层 div【inner-wrapper】,且有很多限制,比如,内层inner-wrapper不能设置高度,且增加了一层冗余的div,很麻烦。

下面有一种完美的实现方式: flex + margin:auto

html 复制代码
<template>
	<div class="outer-wrapper">
		<div class="content">真正的内容区域</div>
	</div>
</template>
<style lang="scss" scoped>
.outer-wrapper {
	width: 100%; // 外层设置宽高
	height: 100%;
	border: 2px solid;
	display: flex;
	justify-content: center; // 可以设置水平居中,但实际不会用这个属性布局
	align-items: center; // 可以设置垂直居中,但实际不会用这个属性布局
	padding: 20px;
	overflow: auto; // 设置滚动
	.content {
		margin: auto; // 实际的垂直居中布局使用的属性
		width: 100%;
		height: 200px;
		flex-shrink: 0;
		background: #ccc;
	}
}
</style>

上面的代码,父元素只需要按照普通的 flex 布局写就行,内容元素增加 margin: auto,就可以实现内容在父元素中的垂直居中。

这里面的知识点是,flex 布局中的每个项目设置了 margin:auto 之后会利用剩余空间自动分配外边距,且优先级高于 justify-content 和 align-items

除了 flex 布局,grid 布局也可以使用margin: auto实现垂直水平居中。

如果是普通的块级元素只能使用 margin: 0 auto实现水平居中,但是垂直居中就无法实现,所以还是尽量使用 flex布局吧。

相关推荐
小杨升级打怪中19 分钟前
前端面经-webpack篇--定义、配置、构建流程、 Loader、Tree Shaking、懒加载与预加载、代码分割、 Plugin 机制
前端·webpack·node.js
Yvonne爱编码32 分钟前
CSS- 4.4 固定定位(fixed)& 咖啡售卖官网实例
前端·css·html·状态模式·hbuilder
SuperherRo1 小时前
Web开发-JavaEE应用&SpringBoot栈&SnakeYaml反序列化链&JAR&WAR&构建打包
前端·java-ee·jar·反序列化·war·snakeyaml
大帅不是我1 小时前
Python多进程编程执行任务
java·前端·python
前端怎么个事1 小时前
框架的源码理解——V3中的ref和reactive
前端·javascript·vue.js
Ciito1 小时前
将 Element UI 表格元素导出为 Excel 文件(处理了多级表头和固定列导出的问题)
前端·vue.js·elementui·excel
不爱吃饭爱吃菜2 小时前
uniapp微信小程序一键授权登录
前端·javascript·vue.js·微信小程序·uni-app
heart000_12 小时前
从零开始打造个人主页:HTML/CSS/JS实战教程
javascript·css·html
90后小陈老师3 小时前
3D个人简历网站 5.天空、鸟、飞机
前端·javascript·3d
不爱吃糖的程序媛7 小时前
浅谈前端架构设计与工程化
前端·前端架构设计