首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

CSS实现元素居中原理解析

在 CSS 中要设置元素水平垂直居中是一个非常常见的需求了。但就是这样一个从理论上来看似乎实现起来极其简单的,在实践中,它往往难住了很多人。...还有一点需要说明是,这种方式实现的垂直居中是“近似”的,并不是完美的垂直居中,因为文字字形的垂直中线位置普遍要比真正的“行框盒子”的垂直中线位置低,而由于我们平时使用的 font-size 比较小,使得这点偏差不容易察觉出来...先让文本换行: 我是要居中的行内元素span 我是要居中的行内元素span...然后设置 .content 元素为绝对定位 position: absolute; 并设置 top: 50%;、left: 50%;,这样.content 元素的左上角就位于 .main 元素的中心了。...然后设置 .content 元素为绝对定位 position: absolute; 并设置 top: 50%;、left: 50%;,这样.content 元素的左上角就位于 .main 元素的中心了。

62120

使用这些 CSS 属性,布局效率又提高了一个层次!

上已经收录,更多往期高赞文章的分类,也整理了很多我的文档,和教程资料。欢迎Star和完善,大家面试可以参照考点复习,希望我们一起有点东西。...最近开源了一个 Vue 组件,还不够完善,欢迎大家来一起完善它,也希望大家能给个 star 支持一下,谢谢各位了。...所以我问自己,为什么不搞篇文章列出所有那些较少使用但既有用又有趣的 CSS 属性? 在本文中,我将介绍一些不一样的CSS属性,希望能给你带来点新鲜感,废话不多说,让我们开始吧。...在CSS网格中使用Place-Items 我们只需使用两行 CSS 代码就可以将元素水平和垂直居中。...object-fit 属性 object-fit属性是相当神奇且有用的。 当我第一次了解它时,它改变了很多事情,使我作为前端开发人员的生活更加轻松。 最近,我正在研究显示徽标网格的部分。

2K20
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    使用这些不太常用的 CSS 属性,让我在前端布局效率上,又提高了一个层次!

    所以我问自己,为什么不搞篇文章列出所有那些较少使用但既有用又有趣的 CSS 属性? 在本文中,我将介绍一些不一样的CSS属性,希望能给你带来点新鲜感,废话不多说,让我们开始吧。...我们只需使用两行 CSS 代码就可以将元素水平和垂直居中。...Flexbox 与 margin 的配合 ? 与flexbox 结合使用,margin: auto 可以非常轻松地将 flex 项目水平和垂直居中。...CSS 的columns 属性是一种布局方法,可以将元素划分为列。 一个常见的用例是将段落文本内容分为两行。 但是,最不常见的是我们可以在列之间添加边框。...object-fit属性是相当神奇且有用的。 当我第一次了解它时,它改变了很多事情,使我作为前端开发人员的生活更加轻松。 最近,我正在研究显示徽标网格的部分。

    2.1K20

    你可能还不知的 7 个 CSS 好用的属性

    就像定义说的,这个属性允许你垂直对齐文本。它对于顺序指示器(st, nd等)、需要的输入星号(*)或没有正确居中的图标特别有用。...下一水平行位于上一行下方。 vertical-rl:对于左对齐(ltr)脚本,内容从上到下垂直流动,下一垂直行位于上一行左侧。...对于右对齐(rtr)脚本,内容从下到上垂直流动,下一垂直行位于上一行右侧。 vertical-lr:对于左对齐(ltr)脚本,内容从上到下垂直流动,下一垂直行位于上一行右侧。...对于右对齐(rtr)脚本,内容从下到上垂直流动,下一垂直行位于上一行左侧。 资源:MDN。 大家都说简历没项目写,我就帮大家找了一个项目,还附赠【搭建教程】。...剪切区域是被引用内嵌的URL定义的路径或者外部svg的路径,或者作为一个形状例如circle()。clip-path属性代替了现在已经弃用的剪切 clip属性。

    1.3K20

    css布局 - 垂直居中布局的一百种实现方式(更新中...)

    新增兄弟节点实力辅助,目标元素轻松上王者 四、父元素高度 不 固定时,多行文本的绝对垂直居中 1....上左50%方位值,先让左上角处于视图中心点  3. margin负边距,再让身子中心点挪到视图中心点 六、目标元素宽高也不固定时,元素依然水平垂直居中(经典弹层布局无宽高)  1. absolute定位飘起来...(特别说明,第三条系列中的父元素height值只是为了撑开然后填充背景色看的。高度不确定不代表没有高度,所以这里是高度值随意改变,内部子元素永远垂直居中的独秀专场)。 那我们派谁打头阵呢?...-- 弹层 - 垂直居中实现 --> 我是宽高固定的弹层元素,我实现了垂直居中。...,但缺点也很明显,它的兼容性不是很好,不兼容 IE6、7而且这样修改display的block变成了table-cell,破坏了原有的块状元素的性质。

    3.5K10

    「css基础」Transforms 属性在实际项目中如何应用?

    本篇文章笔者将带着大家完成以下几个例子: 内容垂直居中 对话框气泡 弹跳的小球 转动的线圈(SVG) 翻转的卡片 本篇文章阅读时间预计15分钟。...01 内容垂直居中 在前端开发过程中,内容居中是常见的需求。其中,居中又可以分为水平居中和垂直居中。水平居中是比较容易的,直接设置元素的margin:0 auto 就可以实现。...使其垂直居中 接下来我们来实现文本垂直居中,有的同学可能想到了使用top属性,实现文本的垂直居中,代码可能是这样的: .child { font-size: 1.2rem; position...细心的同学会注意到,元素的中心位置是在“半像素”这条线上,有可能显得模糊,我们可以添加perspective(视域)属性,让其更清楚,如下代码所示: .child { // ... transform:...(SVG) 这个例子,我们要实现一个更炫的加载提示器,这次我们要做的是基于SVG的动画效果,要理解这部分内容,你需要会svg相关的基础知识,具体的效果如下,感觉就像”头部“的那个东西在牵动线条转圈圈,是不是很酷

    3.3K30

    CSS布局之垂直居中一

    对于块级元素,设置它的margin:auto即可 但是,对于设置垂直居中来说,操作就没那么简单了。 不同情况要不同应对。一般我们可以有三种思路的解决方案。...今天我们先来讨论利用绝对定位解决垂直居中的思路。...然后在通过设置margin-top与margin-left为负值,移动元素到正中心。 当然,我们可以利用CSS3中的clac()方法减少两行代码,效果是一样的。 以上方法是基于元素的宽高都固定。...但在大部分情况中,元素的宽高都是随着父元素的变化而变化。对于不固定宽高的情况,我们又该如何处理呢?...解决办法是利用CSS3的transform属性的translate方法,以本元素自身为基准进行计算和移动 。 本期我给大家介绍了基于绝对定位方式实现垂直居中效果。下期我们讨论另外两种方法。

    70070

    解决CSS垂直居中的几种方法(基于绝对定位,基于视口单位,Flexbox方法)

    在CSS中对元素进行水平居中是非常简单的:如果它是一个行内元素,就对它的父元素应用 text-align: center ;如果它是一个块级元素,就对它自身应用 margin: auto。...然而如果要对一个元素进行垂直居中,可能光是想想就令人头皮发麻了。   多年以来,垂直居中已经成为了CSS领域的圣杯,它同样也是前端开发圈内广为流传的笑话。...3)在实践中,它往往难如登天,当涉及尺寸不固定的元素时尤其如此。       接下来我们具体说明一下这三个方法的简单使用。...这段代码在本质上做了这样几件事情:先把这个元素的左上角放置在视口(或最近的、具有定位属性的祖先元素)的正中心,然后再利用负外边距把它向左、向上移动(移动距离相当于它自身宽高的一半),从而把元素的正中心放置在视口的正中心...不过幸运的是,如果只是想把元素相对于视口进行居中,仍然是有希望的。CSS值与单位(第三版)定义了一套新的单位,称为视口相关的长度单位。       1) vw 是与视口宽度相关的。

    1.8K70

    伸缩布局(CSS3)

    主轴:Flex容器的主轴主要用来配置Flex项目,默认是水平方向 侧轴:与主轴垂直的轴称作侧轴,默认是垂直方向的 方向:默认主轴从左向右,侧轴默认从上到下 主轴和侧轴并不是固定不变的,通过flex-direction...项目位于容器的开头。 让子元素从父容器的开头开始排序但是盒子顺序不变 flex-end 项目位于容器的结尾。 让子元素从父容器的后面开始排序但是盒子顺序不变 center 项目位于容器的中心。...让子元素的高度拉伸适用父容器(子元素不给高度的前提下) center 项目位于容器的中心。 垂直居中 flex-start 项目位于容器的开头。...垂直对齐结束位置 底对齐 5、flex-wrap控制是否换行 当我们子盒子内容宽度多于父盒子的时候如何处理 值 描述 nowrap 默认值。规定灵活的项目不拆行或不拆列。...center 项目位于容器的中心。 flex-start 项目位于容器的开头。 flex-end 项目位于容器的结尾。 space-between 项目位于各行之间留有空白的容器内。

    4.4K50

    android常用布局详解「建议收藏」

    大家好,又见面了,我是你们的朋友全栈君。 view和布局 在一个Android应用程序中,用户界面通过View和ViewGroup对象构建。...LinearLayout 线性布局 线性布局是按照水平或垂直的顺序将子元素(可以是控件或布局)依次按照顺序排列,每一个元素都位于前面一个元素之后。 线性布局分为两种:水平方向和垂直方向的布局。...center:居中显示,这里并不是表示显示在LinearLayout的中心,当LinearLayout线性方向为垂直方向时,center表示水平居中,但是并不能垂直居中,此时等同于 center_horizontal...android:layout_weight: 权重,用来分配当前控件在剩余空间的大小,如果你不设置,所有的视图都有一个layout_weight值,默认为零,意思是需要显示多大的视图就占据多大的屏幕空间...RelativeLayout 相对布局:是一个ViewGroup以相对位置显示它的子视图(view)元素,一个视图可以指定相对于它的兄弟视图的位置(例如在给定视图的左边或者下面)或相对于 RelativeLayout

    2.1K40

    「css基础」Transforms 属性在实际项目中如何应用?

    本篇文章笔者将带着大家完成以下几个例子: 内容垂直居中 对话框气泡 弹跳的小球 转动的线圈(SVG) 翻转的卡片 本篇文章预计15分钟 内容垂直居中 在前端开发过程中,内容居中是常见的需求。...其中,居中又可以分为水平居中和垂直居中。水平居中是比较容易的,直接设置元素的margin:0 auto 就可以实现。但是垂直居中相对来说是比较复杂一些的。...,页面的效果如下图: 53DE0367C3369EC7BFA492A4C15B062D.png 使其垂直居中 接下来我们来实现文本垂直居中,有的同学可能想到了使用top属性,实现文本的垂直居中,代码可能是这样的...细心的同学会注意到,元素的中心位置是在“半像素”这条线上,有可能显得模糊,我们可以添加perspective(视域)属性,让其更清楚,如下代码所示: .child { // ......(SVG) 这个例子,我们要实现一个更炫的加载提示器,这次我们要做的是基于SVG的动画效果,要理解这部分内容,你需要会svg相关的基础知识,具体的效果如下,感觉就像”头部“的那个东西在牵动线条转圈圈,是不是很酷

    2.6K00

    水平垂直居中深入挖掘

    ,如果不手动添加边距(margin 或者 gap),会贴在一起 不限制方向的话,flex 默认是水平排列,grid 是竖直排列 非常重要的一点,grid 布局下的子元素的宽度,所有子元素的宽度会被强行拉伸至最宽的一个子元素的内容的宽度...控制间距 如果我们希望控制每个元素之间的间距呢?我们给 autobot、flex、grid 的容器各自加上 gap: 5px,再看看: .g-container{ gap: 5px; } ?...另外一边溢出 flex 和 grid 都做到了即便超出容器空间,依然是水平垂直居中的 总结一下 经由上述几个 DEMO 可以看出来,在目前比较常用的水平垂直居中方案当中。...flex 方案应该是目前而言最优的选择,它能够在各种环境下都保持内部元素的水平垂直居中并且不改变子元素的某些特征: 便捷的水平垂直居中单个元素 便捷的水平垂直居中多个元素,无论是横向、竖向,亦或内容超出...absolute 无法应付多个元素。 最后 本文知识点比较细,也表明 CSS 虽然简单,但是不代表它容易。我们日常工作中用到的很多属性其实还有很多细节可以挖掘深入。

    99720

    css笔记

    :text">我是文本 尽量不要用hand 因为 火狐不支持 pointer ie6以上都支持的尽量用 轮廓 outline 是绘制于元素周围的一条线,位于边框边缘的外围,可起到突出元素的作用...,是margin: 0 auto; 以前我们还讲过让文字居中对齐,是 text-align: center; 但是我们从来没有讲过有垂直居中的属性, 我们的妈妈一直很担心我们的垂直居中怎么做。...项目位于容器的开头。 让子元素从父容器的开头开始排序但是盒子顺序不变 flex-end 项目位于容器的结尾。 让子元素从父容器的后面开始排序但是盒子顺序不变 center 项目位于容器的中心。...让子元素的高度拉伸适用父容器(子元素不给高度的前提下) center 项目位于容器的中心。 垂直居中 flex-start 项目位于容器的开头。...center 项目位于容器的中心。 flex-start 项目位于容器的开头。 flex-end 项目位于容器的结尾。 space-between 项目位于各行之间留有空白的容器内。

    7.7K50

    【CSS】使用 固定定位 实现顶部导航栏 ( 核心要点 | 固定定位元素居中设置 | 代码示例 )

    0 , 即可设置为顶部导航栏 , 其位置不受页面滚动影响 ; /* 设置固定定位 */ position: fixed; top: 0; 由于顶部的导航栏设置了 绝对定位 , 该元素是脱标的...此处标准流盒子设置 100px 的外边距 防止被顶部的固定定位盒子覆盖 */ margin-top: 55px; 由于设置 绝对 / 固定 定位 , 会将元素变为行内块元素 , 其宽度是内部子元素的宽度..., 如果要精确放置顶部导航栏的位置 , 顶部导航栏盒子必须设置宽度 , 这里选择设置其宽度为 100% ; /* 定位元素如果不设置宽度 默认就是内部内容的宽度 */ /* 如果要设置盒子...*/ text-align: center; /* 该盒子位于最上层 不要被其它盒子覆盖 */ z-index: 3; } 2、固定定位垂直居中设置 设置左右两侧的广告栏在浏览器中垂直居中设置...height: 200px; background-color: purple; } .top { /* 定位元素如果不设置宽度 默认就是内部内容的宽度 */ /*

    3.1K50

    把所有的东西都对齐吧 - 谈谈垂直居中的解决方案

    "44年前我们就把人类送上了月球了,但现在我们仍然无法在css中实现垂直居中 -James Anderson" 难题 在CSS中对元素进行水平居中是非常简单的;如果是一个行内元素,就对父元素设置text-align...:center;如果是一个它是一个块级元素,就对自身应用margin:auto.然而考虑到代码的DRY和较强的可维护性,如果要对一个元素进行垂直居中,可能是令人头皮发麻的一件事情了....就这样在前端开发圈内看似及其常见的需求,从理论上似乎极其简单,在实践中,它往往难如登天,当涉及尺寸不固定的元素时尤为如此....,固定宽度和高度的情况是极少的,对于那些需要居中的元素来说,其尺寸往往是由其内容决定的.如果能够找到一个属性的百分比以元素自身的宽高作为基准,那么难题就迎刃而解!...根据盒对齐模型(第三版)的计划,在未来,对于简单的垂直居中的要求,我们完全不需要动用特殊的布局模式.我们只需要这行代码就可以搞定 align-self:center; 不知不觉间,我们身边的浏览器都开始让它成为现实

    2.3K60

    如何提升你的CSS技能,掌握这20个css技巧即可

    *{ box-sizing:border-box; margin:0; padding:0 } 使用box-sizing声明是可选择,如果你使用下面继承的盒模型形式可以跳过它...,这里的声明没有单位,我们只是告诉浏览器 让它渲染行高是 渲染字体大小的1.5倍 6、垂直居中任何元素 (vertical-center anything) 在没有准备使用CSSGrid 布局的时候,...设置垂直居中布局的全局规则是一个很好的方式,可以为优雅(elegantly)的设置内容布局奠定一个基础 html, body { height: 100%; margin: 0;...设置SVG的格式就跟其他图片类型一样: .logo { background: url("logo.svg"); } 温馨提示:如果将SVG用在可交互的元素上比如说button,SVG...box-decoration-break 假设您希望对换行到多行的长文本行应用统一的间距、边距、突出显示或背景色,但不希望整个段落或标题看起来像一个大块。

    5K20

    CSS——实现元素的垂直居中

    在写CSS的过程中,我常常谷歌一个东西,就是如何实现元素的垂直居中,水平居中难度还不是很大,但是垂直居中我这个烂记性是写一次忘一次,于是本着好记性不如烂笔头的想法,写下一篇博客记录下来。...那么今天就记录下三种垂直居中的方法,各位看官按需使用。 通用情况 首先我们先介绍一种通用情况下的垂直居中,这个方法不需要设置自己的高度,也不需要父容器设置高度,利用绝对定位只需要三行代码就能实现。...,不设置高度 那么来看css代码如何完成垂直居中: #outter1{ position:relative; background:black...若是父容器设置了高度,父容器里只有一个元素,那么使用相对定位即可完成垂直居中。...:center; } 这就是三种CSS里垂直居中的方法了,希望写下这篇文章的我,在遇到垂直居中的问题时,再也不用谷歌了。

    1.3K30
    领券