CSS垂直居中的解决方法

       在CSS中对元素进行水平居中是非常简单的:如果它是一个行内元素,就对它的父元素应用 text-align: center ;如果它是一个块级元素,就对它自身应用 margin: auto。然而如果要对一个元素进行垂直居中,可能光是想想就令人头皮发麻了。

  多年以来,垂直居中已经成为了CSS领域的圣杯,它同样也是前端开发圈内广为流传的笑话。原因在于它同时具备以下几条特征:

              1)它是极其常见的需求。

              2)从理论上来看,它似乎极其简单。

              3)在实践中,它往往难如登天,当涉及尺寸不固定的元素时尤其如此。

      接下来我们具体说明一下这三个方法的简单使用。

一、代码初始化

    我们基于如下这段HTML代码,将id=’content’的div元素在id=’box’的div张垂直居中。

    
这是要居中的元素

登录后复制     基本样式如下:

#box{     margin:0;     padding:0;     width:500px;     height:500px;     background: #4AC291;     font-size:100%;     position: relative;}#content{     background: #655;     color: white;     text-align: center;     line-height: 2em;}

登录后复制CSS垂直居中的解决方法

二、基于绝对定位的解决方法

      如果我们想要利用绝对定位的方法进行垂直剧中的话,那么就要求元素具有固定的宽度和高度,如果没有固定的宽度和高度就无法实现,因为需要利用top和left的值,进行定位。

        #box{            margin:0;            padding:0;            width:500px;            height:500px;            background: #4AC291;            font-size:100%;            position: relative;    //必须的,因为下面的div要根据这个进行定位        }        #content{            background: #655;            color: white;            text-align: center;            line-height: 2em;            position: absolute;   //设置绝对定位            top:50%;            left:50%;            width:12em;            height:2em;            margin-top:-1em;    //    2/2=1            margin-left:-6em;   //    12/2=6      }

登录后复制CSS垂直居中的解决方法

       如上图所示,是固定宽高的样式效果。

  这段代码在本质上做了这样几件事情:先把这个元素的左上角放置在视口(或最近的、具有定位属性的祖先元素)的正中心,然后再利用负外边距把它向左、向上移动(移动距离相当于它自身宽高的一半),从而把元素的正中心放置在视口的正中心。借助强大的 calc() 函数,这段代码还可以省掉两行声明:

        #box{            margin:0;            padding:0;            width:500px;            height:500px;            background: #4AC291;            font-size:100%;            position: relative;        }        #content{            background: #655;            color: white;            text-align: center;            line-height: 2em;          /*position: absolute;            top:50%;            left:50%;            width:12em;            height:2em;            margin-top:-1em;            margin-left:-6em;*/            position: absolute;            width: 12em;            height: 2em;            top: calc(50% - 1em);            left: calc(50% - 6em);      }

登录后复制

       这个方法最大的局限在于它要求元素的宽高是固定的。在通常情况下,对那些需要居中的元素来说,其尺寸往往是由其内容来决定的。如果能找到一个属性的百分比值以元素自身的宽高作为解析基准,那我们的难题就迎刃而解了!遗憾的是,对于绝大多数CSS属性(包括 margin)来说,百分比都是以其父元素的尺寸为基准进行解析的。

三、基于视口单位的解决方法

    假设我们不想使用绝对定位,仍然可以采用translate()技巧来把这个元素以其自身宽高的一半为距离进行移动;但是在缺少left和top的情况下,如何把这个元素的左上角放置的容器的正中心呢?

   我们的第一反应很可能是用margin属性的百分比值来实现,就像这样:

#content {  width: 12em;  margin: 50% auto 0;  transform: translateY(-50%);}

登录后复制CSS垂直居中的解决方法

  这段代码产生的效果十分离谱。原因在于margin的百分比值时以父元素的宽度作为解析基准的。没错,即使对于margin-top和margin-bottom来说也是这样!

  不过幸运的是,如果只是想把元素相对于视口进行居中,仍然是有希望的。CSS值与单位(第三版)定义了一套新的单位,称为视口相关的长度单位。

      1) vw 是与视口宽度相关的。与常人的直觉不符的是,1vw 实际上表示视口宽度的 1%,而不是 100%。

       2)  与 vw 类似,1vh 表示视口高度的 1%。

       3)  当视口宽度小于高度时,1vmin 等于 1vw,否则等于 1vh。

       4)  当视口宽度大于高度时,1vmax 等于 1vw,否则等于 1vh。

四、Flexbox方法(本文主要说明的方法)

      Flexbox(伸缩盒)是专门针对这类需求所设计的。我们之所以要讨论其他方案,仅仅是因为那些方案在浏览器的支持程度上稍微好一些而已。其实目前现代浏览器对 Flexbox 的支持度已经相当不错了。

  我们只需写两行声明即可:先给这个待居中元素的父元素设置 display: flex(在这个例子中是元素),再给这个元素自身设置我们再熟悉不过的margin: auto。

       #box{            display: flex;            min-height:50vh;            margin:0;            width:500px;            height:500px;            background: #4AC291;        }        #content{            margin:auto;            background: #655;            color: white;        }

登录后复制CSS垂直居中的解决方法

        如果浏览器不支持Flexbox,页面渲染结果看起来就跟我们的起点图是一样的了(如果设置了宽度的话)。虽然没有垂直居中效果,但也是完全可以接受的。

  Flexbo 的另一个好处在于,它还可以将匿名容器(即没有被标签包裹的文本节点)垂直居中。

以上就是CSS垂直居中的解决方法的详细内容,更多请关注【创想鸟】其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至253000106@qq.com举报,一经查实,本站将立刻删除。

发布者:PHP中文网,转转请注明出处:https://www.chuangxiangniao.com/p/3122250.html

(0)
上一篇 2025年3月29日 18:10:59
下一篇 2025年3月29日 18:11:07

AD推荐 黄金广告位招租... 更多推荐

相关推荐

  • 如何解决PHP中HTML解析的复杂问题?使用voku/simple_html_dom可以!

    可以通过以下地址学习 Composer:学习地址 在我的项目中,我需要从 html 页面中提取特定内容并进行操作。起初,我尝试使用正则表达式和手动解析,但这不仅耗时,而且容易出错。幸运的是,我找到了 voku/simple_html_dom…

    编程技术 2025年4月5日
    200
  • 使用Composer解决CSS前缀问题:padaliyajay/php-autoprefixer库的实践

    可以通过一下地址学习composer:学习地址 在前端开发中,处理不同浏览器的兼容性问题一直是开发者们的一大挑战。特别是当你需要为 css 属性添加前缀以确保在旧版浏览器中也能正常显示时,这个过程往往是繁琐且容易出错的。最近,在开发一个新项…

    编程技术 2025年4月5日
    300
  • 关于HTML5和CSS替换使用

    听到html5的都知道它的强大,如更多的描述性标记、较少依赖于插件的多媒体支持、跨文档消息通信、web sockets、客户端存储、更强大的表单、提升可访问性、先进的选择器、强大的视觉效果。费话不多说,细细说来 被废弃的标签和属性 废弃的标…

    编程技术 2025年4月4日
    100
  • style对象的cssText方法有哪些使用方法

    这次给大家带来style对象的csstext方法有哪些使用方法,style对象的csstext方法使用的注意事项有哪些,下面就是实战案例,一起来看一下。 cssText 本质是什么?   cssText 的本质就是设置 HTML 元素的 s…

    编程技术 2025年4月4日
    200
  • php无刷新提交表单另一种方法

    通常对于无刷新提交表单,我们都是运用ajax实现的。前段时间了解到另一种无刷新提交表单的方法。现在整理出来分享给大家。 html页面: nbsp;HTML>        无刷新提交表单     ul{ list-style-type…

    编程技术 2025年4月4日
    100
  • 跨平台开发中的Java框架选择

    跨平台 java 应用程序开发的最佳框架选择取决于项目需求。原生开发框架 (swift、kotlin) 提供最佳性能,但需要针对每个平台单独编写代码。跨平台框架 (react native、flutter) 允许代码重用,但性能可能受限。选…

    2025年4月2日
    100
  • eclipse怎么改黑色主题

    要将 Eclipse 的主题更改为黑色,请按照以下步骤操作:1. 打开主题菜单;2. 选择黑色主题;3. 应用更改;4. 重启 Eclipse。使用第三方插件或自定义 CSS 可以进一步自定义主题。 如何修改 Eclipse 为黑色主题 要…

    2025年4月2日
    200
  • eclipse怎么安装emmet

    Emmet 的 Eclipse 安装分以下步骤进行:安装 Emmet 插件:转到菜单栏中的“帮助”>“市场”,搜索并安装“Emmet for Eclipse”。启用 Emmet:重新启动 Eclipse,转到“窗口”>“首选项”…

    2025年4月2日
    200
  • idea怎么刷新项目

    直接刷新项目方法:1. 单击“Reload”按钮(Ctrl + F5);2. 右键单击项目,选择“Reload All from Disk”。强制刷新项目:1. 单击“Invalidate Caches / Restart”按钮(Ctrl …

    2025年4月2日
    300
  • 使用workerman实现在线聊天的方法及原理解析

    使用workerman实现在线聊天的方法及原理解析 随着互联网的发展和智能手机的普及,在线聊天已成为人们生活中不可或缺的一部分。无论是社交媒体上的即时消息还是企业内部的团队协作,都需要一种可靠且高效的在线聊天系统。workerman是一个基…

    2025年4月2日
    200

发表回复

登录后才能评论