CSS 居中总结

news2025/1/12 21:49:28

文章目录

  • CSS 居中总结
    • 水平居中
      • 文字水平居中
      • 块元素水平居中
      • 行内元素和行内块元素水平居中
    • 垂直居中
      • 文字垂直居中
        • 单行文字
        • 多行文字
      • 块元素居中
      • 块元素居中(方法二)
      • 块元素居中(方法三)
      • 行内元素、行内块元素居中
      • flex居中

CSS 居中总结

水平居中

文字水平居中

原理

父元素 {
	text-align: center;
}
<!DOCTYPE html>
<html>
	<head>
		<title></title>
		<style type="text/css">
			div {
				height: 100px;
				text-align: center;
				border: 1px dashed red;
				margin-top: 10px;
			}
		</style>
	</head>
	<body>
		<div>hello world </div>
	</body>
</html>

在这里插入图片描述

块元素水平居中

原理

元素 {
	margin: 0 auto;
}
<!DOCTYPE html>
<html>
    <head>
        <title></title>
        <style type="text/css">
            div {
                margin: 0 auto;
                width: 100px;
                height: 100px;
                background-color: red;
            }
        </style>
    </head>
    <body>
        <div></div>
    </body>
</html>

在这里插入图片描述

行内元素和行内块元素水平居中

原理

父元素 {
	text-align: center;
}
<!DOCTYPE html>
<html>
	<head>
		<title></title>
		<style type="text/css">
			div {
				text-align: center;
				height: 100px;
				text-align: center;
				border: 1px dashed red;
				margin-top: 10px;
			}
		</style>
	</head>
	<body>
		<div>
			<a href="#">hello world</a>
		</div>
		<div>
			<img src="img/logo.png" alt="">
		</div>
	</body>
</html>

在这里插入图片描述

垂直居中

文字垂直居中

单行文字

原理

父元素 {
	height: 高度值;
	line-height: 高度值;
}
<!DOCTYPE html>
<html>
	<head>
		<title></title>
		<style type="text/css">
			div {
				height: 100px;
				line-height: 100px;
				border: 1px dashed red;
			}
		</style>
	</head>
	<body>
		<div>hello world</div>
	</body>
</html>

在这里插入图片描述

多行文字

原理

父元素 {
	display: table-cell;
    vertical-align: middle;
}

span {
	display: inline-block;
}
<!DOCTYPE html>
<html>
	<head>
		<title></title>
		<style type="text/css">
			p {
				display: table-cell;
				vertical-align: middle;
				width: 400px;
				height: 200px;
				border: 1px dashed red;
			}

			span {
				display: inline-block;
			}
		</style>
	</head>
	<body>
		<p>
			<span>这是一堆文本这是一堆文本这是一堆文本<br />
				这是一堆文本这是一堆文本<br />
				这是一堆文本这是一堆文本这是一堆文本这是一堆文本这是一堆文本</span>
		</p>
	</body>
</html>

在这里插入图片描述

块元素居中

原理

使用position定位元素,这种方式适用于block元素。

父元素 {
	position: relative;
}

子元素 {
	position: absolute;
    top: 50%;
    left: 50%;
    margin-top: height值一半的负值;
    margin-left: width值一半的负值;
}
<!DOCTYPE html>
<html>
	<head>
		<title></title>
		<style type="text/css">
			#father {
				position: relative;
				width: 200px;
				height: 160px;
				border: 1px solid gray;
			}

			#son {
				position: absolute;
				top: 50%;
				left: 50%;
				margin-top: -30px;
				margin-left: -50px;
				width: 100px;
				height: 60px;
				background-color: Red;
			}
		</style>
	</head>
	<body>
		<div id="father">
			<div id="son"></div>
		</div>
	</body>
</html>

在这里插入图片描述

块元素居中(方法二)

原理

用translate替代margin。

元素 {
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
}
<!DOCTYPE html>
<html>
	<head>
		<title></title>
		<style type="text/css">
			#father {
				position: relative;
				width: 200px;
				height: 160px;
				border: 1px solid gray;
			}

			#son {
				width: 100px;
				height: 60px;
				background-color: Red;
				position: absolute;
				top: 50%;
				left: 50%;
				transform: translate(-50%, -50%);
			}
		</style>
	</head>
	<body>
		<div id="father">
			<div id="son"></div>
		</div>
	</body>
</html>

在这里插入图片描述

块元素居中(方法三)

原理

元素 {
    position: absolute;
    top: 0;
    bottom: 0;
    left: 0;
    right: 0;
    margin: auto;
}
<!DOCTYPE html>
<html>
	<head>
		<title></title>
		<style type="text/css">
			#father {
				position: relative;
				width: 200px;
				height: 160px;
				border: 1px solid gray;
			}

			#son {
				width: 100px;
				height: 60px;
				background-color: Red;
				position: absolute;
				top: 0;
				bottom: 0;
				left: 0;
				right: 0;
				margin: auto;
			}
		</style>
	</head>
	<body>
		<div id="father">
			<div id="son"></div>
		</div>
	</body>
</html>

在这里插入图片描述

行内元素、行内块元素居中

使用table-cell属性,这种方式适用于inline元素、inline-block元素。

原理

父元素 {
	display:table-cell;
	vertical-align:middle;
}

子元素 {
	vertical-align:middle; 
}
<!DOCTYPE html>
<html>
	<head>
		<title></title>
		<style type="text/css">
			div {
				display: table-cell;
				vertical-align: middle;
				text-align: center;
				width: 240px;
				height: 160px;
				border: 1px solid red;
				margin-top: 10px;
			}

			img {
				vertical-align: middle;
				width: 50%;
				height: 50%;
			}
		</style>
	</head>
	<body>
		<div>
			<a href="#">hello world</a>
		</div>
		<br>
		<div>
			<img src="img/a.png" alt="" />
		</div>
	</body>
</html>

在这里插入图片描述

flex居中

<!DOCTYPE html>
<html>
	<head>
		<title></title>
		<style type="text/css">
			#father {
				display: flex;
				align-items: center;
				justify-content: center;
				width: 200px;
				height: 160px;
				border: 1px solid gray;
			}

			#son {
				width: 100px;
				height: 60px;
				background-color: Red;
			}
		</style>
	</head>
	<body>
		<div id="father">
			<div id="son"></div>
		</div>
	</body>
</html>

在这里插入图片描述

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/85966.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

web前端期末大作业实例 (1500套) 集合

文章目录&#x1f4da;web前端期末大作业 (1500套) 集合一、网页介绍二、网页集合&#x1f48c;表白网页 125套 (集合)&#x1f499;Echarts大屏数据展示 150套 (集合)一、基于HTMLEcharts技术制作二、基于VUEEcharts技术制作&#x1f381;更多源码&#x1f4da;web前端期末大作…

去中心化的互联网环境,有一种神奇的商业模式,无产品也可以创业

现在的电商行业做分销的平台越来越多&#xff0c;竞争力也越渐增大&#xff0c;不得不使用一些电商商业模式来让用户进来并留下来。 ​ 但是在经济环境和疫情环境的双重影响下&#xff0c;每个人或多或少都被影响到了。虽然有很多行业低落&#xff0c;但是也有一些行业兴起&…

Spring事务及Spring整合MyBatis

SM整合的步骤 1&#xff0c;建库建表 2&#xff0c;新建maven模块 3&#xff0c;修改maven目录 4&#xff0c;修改pom.xml文件&#xff0c;添加依赖 5&#xff0c;添加MyBaits模板&#xff08;SqlMapperConfig.xml和XXXMapper.xml文件&#xff09; 6&#xff0c;添加Appli…

小程序中的轮播图

目录 小程序的宿主环境 - 组件 1.scroll-view 组件的基本使用2.swiper 和 swiper-item 组件的基本使用3.text 组件的基本使用4.rich-text 组件的基本使用附&#xff1a;微信小程序轮播图单独添加图片、修改轮播图图片、单独修改某张图片总结 小程序的宿主环境 - 组件 1.scrol…

北京智和信通:交换机策略查询与自动化配置

在网络中交换机占据重要位置&#xff0c;一旦交换机被攻击或破坏&#xff0c;都将使整个网络处于危险之中。在网络的日常配置管理中&#xff0c;交换机的配置也是核心工作&#xff0c;但在交换机的配置过程复杂&#xff0c;而且根据品牌及型号的不同&#xff0c;配置方式也不相…

利用2阶分数阶微分掩模的边缘检测(Matlab代码实现)

&#x1f468;‍&#x1f393;个人主页&#xff1a;研学社的博客 &#x1f4a5;&#x1f4a5;&#x1f49e;&#x1f49e;欢迎来到本博客❤️❤️&#x1f4a5;&#x1f4a5; &#x1f3c6;博主优势&#xff1a;&#x1f31e;&#x1f31e;&#x1f31e;博客内容尽量做到思维缜…

java计算机毕业设计基于安卓Android的装维助手APP

项目介绍 随着科学技术的飞速发展,各行各业都在努力与现代先进技术接轨,通过科技手段提高自身的优势&#xff1a;对于装维助手APP当然也不能排除在外,随着网络技术的不断成熟,带动了装维助手APP,它彻底改变了过去传统的管理方式,不仅使服务管理难度变低了,还提升了管理的灵活性…

服务器负载过高实例分析

一、问题现象 top 命令查看显示服务器负载情况&#xff0c;服务器负载1.31&#xff0c;而且长时间没降下去&#xff0c;CPU使用率99.9%也异常飚高 load average &#xff1a;系统平均负载均值&#xff0c;三列分别代表 1分钟、5分钟、15分钟。理论上&#xff0c;值越小越好。负…

C4D中使用python脚本1

学习视频链接 关于C4D与Python那些事_哔哩哔哩_bilibilihttps://www.bilibili.com/video/BV1et411172W/ 目录 一、简单用法 二、C4D包 2.1 vector 矢量 2.2 矩阵 2.3 用脚本创建对象 2.4 几何体结构 三、制作效果 3.1 洗牌 3.2 后面的项目单独开文章 一、简单用法 …

java小技能:对list集合根据条件进行分组、过滤和字段筛选

文章目录 引言I 对list根据条件进行分组1.1 费率信息实体1.2 dto1.3 查询数据II 对list根据条件进行过滤和字段筛选1.1 代理商配置角色权限步骤1.2 实体1.3 穿透删除所有下级代理商相对应的权限值引言 需求背景:查询机构下的代理商费率信息,查询结果对分润和返利进行分组。 …

【云计算与大数据技术】Spark的解析(图文解释 超详细必看)

一、Spark RDD Spark是一个高性能的内存分布式计算框架&#xff0c;具备可扩展性&#xff0c;任务容错等特性&#xff0c;每个Spark应用都是由一个driver program 构成&#xff0c;该程序运行用户的 main函数 。 Spark提供的一个主要抽象就是 RDD(Resilient Distributed Data…

Java搭建宝塔部署实战SSM智能养生平台管理系统源码

大家好啊&#xff0c;我是测评君&#xff0c;欢迎来到web测评。 本期给大家带来一套Java开发的SSM智能养生平台管理系统源码。 技术架构 技术框架&#xff1a;ssm layui jsp mybatis bootstrap jquery mysql5.7运行环境&#xff1a;jdk8 nginx1.20 tomcat9 IntelliJ …

与电装DENSO建立EDI连接需要掌握哪些信息?

项目背景 株式会社电装DENSO CORPORATION是世界汽车零部件及系统的顶级供应商&#xff0c;在2013年《财富》周刊公布的世界500强企业排名中&#xff0c;位列第242名。作为世界顶级汽车技术、系统以及零部件的全球性供应商&#xff0c;电装在环境保护、发动机管理、车身电子产品…

DocuWare平台——用于文档管理和工作流程自动化的内容服务平台详细介绍(下)

接上篇~~ 三、处理文档、控制工作流程 顺畅的信息流是每个生产过程的基础。自动化任何基于文档的任务&#xff08;从有效的重新提交文档到复杂的审批工作流程&#xff09;&#xff0c;让您的团队在跨组织和跨部门的工作中畅通无阻。 具有列表的任务管理 通过自动汇总当前信…

数字分类

目录 1012:数字分类 输入格式&#xff1a; 输出格式&#xff1a; 输入样例 1&#xff1a; 输出样例 1&#xff1a; 输入样例 2&#xff1a; 输出样例 2&#xff1a; 代码长度限制: 时间限制: 内存限制: 思路: 1.变量存储 1.2代码: 大坑,好多坑: 坑点1&#xff1…

Android 动态分区详解(六) 动态分区的底层机制

文章目录 1. Android 动态分区的两重含义2. device mapper 的原理3. linear 映射的原理3.1 多个设备映射示例3.2 `dmsetup create` 命令参数解释1. `dmsetup create` 命令2. 映射表格式解析3.3 单个设备映射示例1. 使用 dmsetup 映射单个设备2. 使用 dmctl 映射 super 设备本文…

二、物理层(二)传输介质和物理层设备

目录 2.1物理层概述 2.2导向型传输介质 2.2.1双绞线 2.2.2同轴电缆 2.2.3光纤 2.3非导向型传输介质 2.3.1无线电波 2.3.2微波 2.3.3红外线、激光 2.4物理层设备 2.4.1中继器 2.4.2集线器 2.1物理层概述 物理层考虑的是如何在连接到各种计算机的传输媒体上传输数据比…

推断统计 | 学习笔记 (全)

一.概率与概率分布 概率论&#xff1a;为解决不确定性问题提供方法 1.随机事件及其概率 基本概念 试验&#xff1a;在相同条件下&#xff0c;对事物或现象所进行的观察。特点是可以在相同的条件下重复进行&#xff1b;每次试验的可能结果不止一个&#xff0c;但试验的所有可…

QT—QString类

一、隐式共享 隐式数据共享机制去最大化资源有效利用和最小化复制克隆操作。隐式共享类当作为函数参数传递的时候&#xff0c;不仅安全而且效率很高&#xff0c;因为传递的时候只是传递的数据的指针&#xff0c;数据本身只当自己被修改的时候才会去复制。简称写时复制。数据相…

【AI with ML】第 2 章 :计算机视觉简介

&#x1f50e;大家好&#xff0c;我是Sonhhxg_柒&#xff0c;希望你看完之后&#xff0c;能对你有所帮助&#xff0c;不足请指正&#xff01;共同学习交流&#x1f50e; &#x1f4dd;个人主页&#xff0d;Sonhhxg_柒的博客_CSDN博客 &#x1f4c3; &#x1f381;欢迎各位→点赞…