好消息,align-content垂直居中也适用普通元素啦

这篇文章发布于 2024年09月13日,星期五,23:36,归类于 CSS相关。 阅读 4623 次, 今日 9 次 4 条评论

 

封面图 兔子

一、普大喜奔好消息

好消息,实现元素垂直居中对齐终于有了专门的CSS属性,就是之前Flex布局和Grid布局中使用的align-content属性,现在已经可以在普通的block块级元素中使用啦!

普通块级元素也支持

案例演示

例如,有如下CSS和HTML代码:

<ul>
  <li>《HTML并不简单》这本书不错</li>
  <li>感谢正版支持《CSS新世界》</li>
</ul>
ul {
  height: 150px;
  border: solid;
  align-content: center;
}

此时的渲染效果如下图所示,真就垂直居中了。

垂直居中结果示意

我只能说——Nice!

Nice!

二、自然也支持居底

因为支持的是align-content属性,并不仅仅是某一个属性值,因此,普通元素内的居底效果,也是轻松支持的,例如下面的柱状图实现效果:

<div class="box">
    <div class="bar" style="--percent: 20"></div>
    <div class="bar" style="--percent: 40"></div>
    <div class="bar" style="--percent: 70"></div>
    <div class="bar" style="--percent: 50"></div>
</div> 
.box {
    height: 200px;
    border-bottom: 1px solid;    
    border-left: 1px solid;
    align-content: end;
}
.bar {
    display: inline-block;
    width: 10px;
    margin-inline: 20px;
    background-color: green;
    height: calc(1% * var(--percent));
    vertical-align: bottom;
}

就可以有如下图所示的对齐效果了,不再需要像过去那样,使用辅助元素,或者必须使用Flex布局了。

柱状图底部对齐

眼见为实,您可以狠狠地点击这里:CSS align-content让普通元素柱状图居底demo

三、那水平居中呢?

OK,垂直居中的align-content属性支持了,那么水平内容居中的justify-content属性呢?

很多人可能会觉得应该会支持,毕竟两者的区别看起来就在于方向嘛。

实际上,普通元素并不支持justify-content属性,必须Flex布局或者Grid布局。

参见浏览器的提示信息:

普通元素不支持justify-content说明截图

四、那place-content属性呢?

place-content属性是align-contentjustify-content属性的合写,因此,当普通元素应用place-content属性的时候,仅支持方向会有对应的效果,例如:

<p>
  <img src="1.jpg" width="256">
</p>
p {
  border: solid;
  height: 300px;
  width: 300px;
  place-content: center;
}

此时,图片仅垂直居中,并未水平居中,如下截图所示:

图片仅垂直居中示意

五、耶,假期来了

连上6天班太累了,所以,明天,也就是周六9月14日请年假了。

诸位好好安心工作,我先出门钓鱼为敬了,哈哈,就是不知道明天能不能爆护。

其他就不多说什么了。

提前祝大家中秋节快乐,台风散去。

???

(本篇完)

分享到:


发表评论(目前4 条评论)

  1. 小舟说道:

    查到了 chrome 123版本开始支持
    https://caniuse.com/?search=align-content

  2. 小舟说道:

    chrome多少版本开始支持呀

  3. 小牛说道:

    看完第一段就在想,那justify-content呢。靠,张老师啥都想到了。

    新书马上支持。

  4. 观海说道:

    nb