位置: IT常识 - 正文

8种css居中实现的详细实现方式了(css各种居中)

编辑:rootadmin
8种css居中实现的详细实现方式了

推荐整理分享8种css居中实现的详细实现方式了(css各种居中),希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:css实现居中的方法,css中居中显示的代码怎么写,css各种居中,css实现居中的方法,css居中的几种方法,css居中的几种方式,css各种居中,css各种居中,内容如对您有帮助,希望把文章链接给更多的朋友!

这是一篇关于居中对齐方式的总结

开篇之前,先问一下大家都知道几种居中的实现方式?

面试时答出来两三个就不错了,就怕面试官还让你继续说。今天就来总结一下这些居中的方式

使用flex布局设置居中。使用flex 时也能通过给子项设置margin: auto实现居中。使用绝对定位的方式实现水平垂直居中。使用grid设置居中。使用grid时还能通过给子项设置margin: auto实现居中。使用tabel-cell实现垂直居中。还有一种不常用的方法实现垂直居中。最后还有一种奇葩的方法。容器设置position: relative。孩子设置 top、left、bottom、right都设置为01.flex布局设置居中

常见的一种方式就是使用flex布局设置居中。

利用弹性布局(flex),实现水平居中,其中justify-content 用于设置弹性盒子元素在主轴(横轴)方向上的对齐方式

给容器设置:

display: flex;写在父元素上这就是定义了一个伸缩容器

justify-content 主轴对齐方式,默认是横轴

align-items 纵轴对齐方式,默认是纵轴

优点: 简单、方便、快速,三行代码搞定。

<div class="box"> <div class="child">水平垂直居中</div></div><style>.box { width: 200px; height: 200px; border: 1px solid; display: flex; align-items: center; // 纵轴对齐方式,默认是纵轴 子元素垂直居中 justify-content: center; //纵轴对齐方式,默认是纵轴}.child { background: red;} </style>

代码片段

2.flex-给子项设置

第一种方式是给父盒子设置属性,这一种是给子盒子设置margin: auto实现居中。给容器设置 display: flex; 子项设置 margin: auto;

<div class="box"> <div class="child">水平垂直居中</div></div><style>.box { width: 200px; height: 200px; border: 1px solid; display: flex;}.child { background: red; margin: auto; // 水平垂直居中} </style>

代码片段

3.绝对定位

使用绝对定位的方式实现水平垂直居中。容器设置position: relative。子元素设置 position: absolute; left: 50%; top: 50%; transfrom: translate(-50%, -50%);

8种css居中实现的详细实现方式了(css各种居中)

优点就是不用关心子元素的长和宽,但是这种方法兼容性依赖translate2d的兼容性

<div class="box"> <div class="child">水平垂直居中</div></div><style>.box { width: 200px; height: 200px; border: 1px solid; position: relative;}.child { position: absolute; left: 50%; top: 50%; transform: translate(-50%, -50%); background: red;} </style>

代码片段

4.tabel-cell实现垂直居中

css新增的table属性,可以让我们把普通元素,变为table元素的现实效果,通过这个特性也可以实现水平垂直居中

而且tabel单元格中的内容天然就是垂直居中的,只要添加一个水平居中属性就好了

使用tabel-cell实现垂直居中,容器设置 display: table-cell;;

vertical-align: middle属性设置元素的垂直对齐方式

子元素如果是块级元素,直接使用左右margin:auto实现水平居中。如果是行内元素,给容器设置text-align: center

利用 text-align: center 可以实现在块级元素内部的内联元素水平居中。此方法对内联元素inline, 内联块inline-block, 内联表inline-table, inline-flex元素水平居中都有效。

<div class="box"> <div class="child">水平垂直居中</div></div><style>.box { width: 200px; height: 200px; border: 1px solid; display: table-cell; vertical-align: middle; // 设置元素在垂直方向上的对齐方式 text-align: center;}.child { background: red; display: inline-block;} </style>

代码片段

5.grid设置居中使用grid设置居中。给容器设置 display: grid; align-items: center; justify-content: center;

通过给容器设置属性,达到居中效果,但是这种方式兼容性较差,不推荐。

<div class="box"> <div class="child">水平垂直居中</div></div><style>.box { width: 200px; height: 200px; border: 1px solid; display: grid; align-items: center; justify-content: center;}.child { background: red;} </style>

代码片段

6.grid给子项设置

使用grid时还能通过给子项设置margin: auto;实现居中。给容器设置 display: grid; 子项设置 margin: auto;

某些浏览器会不支持grid布局方式,兼容性较差,不推荐。

<div class="box"> <div class="child">水平垂直居中</div></div><style>.box { width: 200px; height: 200px; border: 1px solid; display: grid;}.child { background: red; margin: auto;} </style>

代码片段

7.给容器加给伪元素

这是一种不常用的方法实现垂直居中。给容器加给伪元素,设置line-height等于容器的高度。给孩子设置display: inline-block;

<div class="box"> <div class="child">水平垂直居中</div></div><style>.box { width: 200px; height: 200px; border: 1px solid; text-align: center;}.box::after { content: ""; line-height: 200px;}.child { display: inline-block; background: red;}</style>

代码片段

8.还有一种奇葩的方法

这个奇葩方式和第三种使用绝对定位相似,只不过需要给子元素设置 position: absolute; 设置固定宽度和高度;top、left、bottom、right都设置为0; margin设置为auto;也能实现垂直水平居中。

<div class="box"> <div class="child">水平垂直居中</div></div><style>.box { width: 200px; height: 200px; border: 1px solid; position: relative;}.child { background: red; width: 100px; height: 40px; position: absolute; left: 0; top: 0; right: 0; bottom: 0; margin: auto;} </style>

代码片段

以上就是一些我们常用的垂直居中的方案。

本文链接地址:https://www.jiuchutong.com/zhishi/298394.html 转载请保留说明!

上一篇:yolov5训练自己的数据集,OpenCV DNN推理(yolov5训练自己的模型配置到单片机)

下一篇:模型训练步骤(模型训练的过程是什么过程)

  • 广告公司的税务
  • 新公司需要去当地街道报备劳动关系证明吗
  • 资产负债表的其他流动资产包括哪些
  • 车险 保险金额
  • 利润分配的规则
  • 加计抵减税额账务处理
  • 赠送的产品价格为0怎么入库
  • 合理合法的纳税人是谁
  • 现金支票怎么支付的
  • 外购无形资产的相关税费包括增值税吗
  • 计提增值税小于10万元
  • 厂家给经销商的授权书
  • 支付利息的诉讼请求
  • 预收账款和预付账款什么时候用
  • 资产处置收益结转损益
  • 转账支票背书有时间限制吗
  • 周转材料属于什么会计要素
  • 异地承包工程预缴什么税?
  • 去税局代开增值税专票需要什么资料?
  • 增值税税额转出申报怎么填写
  • 公司没有车牌可以买车吗
  • 股票现金分红
  • 企业自有固定资产有哪些
  • 建筑业月末账务处理
  • 劳务费个人所得税税率
  • 一般纳税人附加税费减免政策
  • 旧物品翻新
  • 暂估固定资产原值减少
  • 华为手机怎么删除多余的桌面
  • 如何解决蓝屏错误代码0x000007B问题
  • win 11 中文
  • oeloader.exe - oeloader是什么进程 有什么用
  • 允许税前扣除的税金
  • php功能实现
  • 废品损失的核算一定要设废品损失账户吗
  • 资产负债表和利润表的认定
  • 局部规划算法
  • chmod命令用于更改文件或目录的所有者
  • 外埠存款通过哪个会计账户核算?
  • python如何设置窗口背景色
  • 纳税申报和账务不一致
  • 受托加工收到的材料怎么入账
  • python PaddleOCR库的介绍
  • 出租缴纳房产税
  • tomcat结构图
  • 有形动产租赁属于现代服务业吗
  • 预付账款需要做预算凭证吗
  • 委托加工业务中需要计算缴纳增值税销项税
  • 公众号注册验证退款
  • 信用证保证金的计算公式
  • 原始凭证错误的更正方法
  • 去年印花税今年年初交的税金及附加做今 年可以吗
  • 企业重组合并
  • 餐饮行业的原材料怎么做账
  • 营业执照代办需要什么手续
  • 老生常谈啥意思
  • 双击盘符弹出属性
  • 卷影复制是什么
  • centos账号密码
  • solaris的多线程实现方式
  • win8系统怎么查看隐藏文件
  • browsercore.exe是什么
  • win8 开机
  • 内存运行linux
  • a4腰多大
  • android入门教程
  • 页面模板排序
  • python win32print
  • 下列关于android的说法中,错误的是
  • 安卓匿名电话软件
  • 浏览器复制插件在哪
  • php和js的区别和联系
  • jquery点击事件写法
  • Nodejs+angularjs结合multiparty实现多图片上传的示例代码
  • 如何获取android实体类保存的数据
  • jquery使用css方法添加图片边框视频教学
  • flask框架下使用scrapy框架
  • 核定征收怎么计算税额
  • 税务催报通知书怎么接收
  • 企业资金运转资金投放
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

    网站地图: 企业信息 工商信息 财税知识 网络常识 编程技术

    友情链接: 武汉网站建设