当前位置:首页 > 科技  > 软件

尝试借助CSS @container实现多行文本展开收起

来源: 责编: 时间:2023-12-18 09:46:36 349观看
导读之前写过这样一篇文章:CSS 实现多行文本“展开收起”,介绍了一些纯 CSS 实现多行文本展开收起的小技巧,非常巧妙,有兴趣的可以回顾一下。不过展开收起按钮的隐藏和显示采用了“障眼法”,也就是通过一个伪元素设置和背景相

d6G28资讯网——每日最新资讯28at.com

之前写过这样一篇文章:CSS 实现多行文本“展开收起”,介绍了一些纯 CSS 实现多行文本展开收起的小技巧,非常巧妙,有兴趣的可以回顾一下。d6G28资讯网——每日最新资讯28at.com

d6G28资讯网——每日最新资讯28at.com

不过展开收起按钮的隐藏和显示采用了“障眼法”,也就是通过一个伪元素设置和背景相同的颜色覆盖实现的,如下:d6G28资讯网——每日最新资讯28at.com

d6G28资讯网——每日最新资讯28at.com

:时代在进步,CSS也在不断发展。 CSS 容器查询[1]出来也有一段时间了,能够动态判断容器尺寸,赶紧拿来用一下,发现并没有想象中的那么顺利,甚至还有些难用,一起看看吧d6G28资讯网——每日最新资讯28at.com

一、简单介绍一下容器查询

CSS 容器查询,顾名思义,就是可以动态查询到容器的尺寸,然后设置不同的样式。d6G28资讯网——每日最新资讯28at.com

比如有这样一个容器。d6G28资讯网——每日最新资讯28at.com

<div class="card">  <h2>欢迎关注前端侦探</h2></div>

简单美化一下。d6G28资讯网——每日最新资讯28at.com

.card{  display: grid;  place-content: center;  width: 350px;  height: 200px;  background-color: #FFE8A3;  border-radius: 8px;  border: 1px dashed #9747FF;}

效果如下:d6G28资讯网——每日最新资讯28at.com

d6G28资讯网——每日最新资讯28at.com

现在这个容器宽度是 350px,现在希望在宽度小于 250px时文字颜色变为绿色,要怎么做呢?d6G28资讯网——每日最新资讯28at.com

非常简单,只需要规定一下容器的类型,然后写一个查询语句就行了,关键实现如下:d6G28资讯网——每日最新资讯28at.com

.card{  /**/  container-type: size;}@container (width < 250px){  .card h2{    color: #14AE5C;  }}

这样在动态改变元素尺寸时就会自动改变颜色了,效果如下d6G28资讯网——每日最新资讯28at.com

d6G28资讯网——每日最新资讯28at.com

是不是非常简单?d6G28资讯网——每日最新资讯28at.com

可事实是这样吗,其实还有很多局限。d6G28资讯网——每日最新资讯28at.com

二、容器查询的局限

主要是有两点局限。d6G28资讯网——每日最新资讯28at.com

第一点,容器查询不可更改容器本身样式,比如像这样,直接改颜色是不生效的。d6G28资讯网——每日最新资讯28at.com

.card{  /**/  container-type: size;}@container (width < 250px){  .card{    color: #14AE5C;  }}

白白浪费了一层标签。d6G28资讯网——每日最新资讯28at.com

也无法通过:has去匹配父级。d6G28资讯网——每日最新资讯28at.com

.card{  /**/  container-type: size;}@container (width < 250px){  body:has(.card h2){    color: #14AE5C;  }}

还有一点问题更大,容器必须手动指明尺寸,不可以由内容撑开,也就是自适应内容尺寸,比如我们将上面的宽高去除d6G28资讯网——每日最新资讯28at.com

d6G28资讯网——每日最新资讯28at.com

可以看到,在设置成容器查询类型后,「容器的宽高都变成了 0」,必须手动设置宽高。d6G28资讯网——每日最新资讯28at.com

所以,在实际应用中,必须要想办法规避这两个问题。d6G28资讯网——每日最新资讯28at.com

三、多行文本展开收起中的应用

现在回头看多行文本的例子,通过之前的文章,我们可以很“轻松”的实现这样一个布局,如果不太清楚的可以回顾一下,这里就不多描述了d6G28资讯网——每日最新资讯28at.com

<div class="text-wrap">  <div class="text-content">    <label class="expand"><input type="checkbox" hidden></label>    欢迎关注前端侦探,这里有一些有趣的、你可能不知道的HTML、CSS、JS小技巧技巧。  </div></div>

相关样式如下:d6G28资讯网——每日最新资讯28at.com

.text-wrap{  display: flex;  position: relative;  width: 300px;  padding: 8px;  outline: 1px dashed #9747FF;  border-radius: 4px;  line-height: 1.5;  text-align: justify;  font-family: cursive;}.expand{  font-size: 80%;  padding: .2em .5em;  background-color: #9747FF;  color: #fff;  border-radius: 4px;  cursor: pointer;}.expand::after{  content: '展开';}.text-content{  display: -webkit-box;  -webkit-box-orient: vertical;  -webkit-line-clamp: 3;  overflow: hidden;}.text-content::before{  content: '';  float: right;  height: calc(100% - 24px);}.expand{  float: right;  clear: both;  position: relative;}.text-wrap:has(:checked) .text-content{  -webkit-line-clamp: 999;}.text-wrap:has(:checked) .expand::after{  content: '收起';}

这样就得到了一个“右下角”可以展开收起的布局,不过目前按钮是始终可见的。d6G28资讯网——每日最新资讯28at.com

d6G28资讯网——每日最新资讯28at.com

我们尝试用容器查询来判断一下:d6G28资讯网——每日最新资讯28at.com

.text-wrap{  /**/  container-type: size;}

结果...高度都变成了 0。d6G28资讯网——每日最新资讯28at.com

d6G28资讯网——每日最新资讯28at.com

所以直接添加是不行的。d6G28资讯网——每日最新资讯28at.com

有什么办法可以让容器查询可以自适应内容高度呢?我这里想到的办法是,外层用一个自适应内容高度的容器,然后容器查询盒子用绝对定位的方式,高度跟随外层,原理如下:d6G28资讯网——每日最新资讯28at.com

d6G28资讯网——每日最新资讯28at.com

因此,我们需要添加两层,一层作为自适应内容的容器,一层作为容器查询盒子,自适应内容的文本可以用伪元素来代替,和真实内容保持一致就行了。d6G28资讯网——每日最新资讯28at.com

<div class="text-wrap">    <div class="text" title="欢迎关注前端侦探,这里有一些有趣的、你可能不知道的HTML、CSS、JS小技巧技巧。">      <div class="text-size">        <div class="text-flex">          <div class="text-content">            <label for="check" class="expand"><input type="checkbox" id="check" hidden></label>            欢迎关注前端侦探,这里有一些有趣的、你可能不知道的HTML、CSS、JS小技巧技巧。          </div>        </div>      </div>    </div>  </div>

然后把.text-size座位容器查询盒子。d6G28资讯网——每日最新资讯28at.com

.text-size{  position: absolute;  inset: 0;  container-type: size;}@container (height <= 4.5em) {  .text-size .expand{    display: none;  }}

虽然现在有点乱,但容器查询已经生效了,在小于等于4.5em(3行)的时候,右下角按钮已经消失了。d6G28资讯网——每日最新资讯28at.com

d6G28资讯网——每日最新资讯28at.com

如果隐藏占位伪元素,其实是这样的。d6G28资讯网——每日最新资讯28at.com

d6G28资讯网——每日最新资讯28at.com

空出一大段空白确实不雅,由于我们需要查询的高度是最大高度,所以外层自适应高度不能再变了,相当于 JS 中的 scrollHeight,因此,这层容器需要设置绝对定位,从而不影响最外层容器。d6G28资讯网——每日最新资讯28at.com

.text{  position: absolute}

同时将占位伪元素隐藏后,效果如下:d6G28资讯网——每日最新资讯28at.com

d6G28资讯网——每日最新资讯28at.com

现在高度都回到了0,因此我们需要额外一份文本来自适应最外层容器,而且也能展开收起。d6G28资讯网——每日最新资讯28at.com

<div class="text-wrap">  <div class="text" title="欢迎关注前端侦探,这里有一些有趣的、你可能不知道的HTML、CSS、JS小技巧技巧。">    <div class="text-size">      <div class="text-flex">        <div class="text-content">          <label class="expand"><input type="checkbox" hidden></label>          欢迎关注前端侦探,这里有一些有趣的、你可能不知道的HTML、CSS、JS小技巧技巧。        </div>      </div>    </div>  </div>  <div class="text-content text-place">    欢迎关注前端侦探,这里有一些有趣的、你可能不知道的HTML、CSS、JS小技巧技巧。  </div></div>

我们只需要它的高度,所以可以设置为不可见。d6G28资讯网——每日最新资讯28at.com

.text-place{  visibility: hidden;}

这样容器的高度其实是由text-place这一层撑开的,效果如下:d6G28资讯网——每日最新资讯28at.com

d6G28资讯网——每日最新资讯28at.com

总算实现了动态查询自适应文本容器高度,效果如下:d6G28资讯网——每日最新资讯28at.com

d6G28资讯网——每日最新资讯28at.com

还有很多细节,可以查看以下 demo。d6G28资讯网——每日最新资讯28at.com

  • CSS @container clamp (juejin.cn)[2]
  • CSS @container clamp (codepen.io)[3]

四、总结:容器查询还是不太适合

总的来说,容器查询并没有想象中那么“好用”,甚至有些难用,也有可能使用过场景并不在这里,虽然最终勉强实现了,但是代价太大了,多了两份相同的文本内容,HTML结构也复杂了好多。下面总结一下d6G28资讯网——每日最新资讯28at.com

  • 容器查询可以根据容器的尺寸匹配不同的样式。
  • 容器查询并没有那么“好用”,有两个局限性。
  • 一个是容器查询不可更改容器本身样式,导致白白浪费一层标签。
  • 还有一个是容器必须手动指明尺寸,不可以由内容撑开,也就是自适应内容尺寸,否则容器尺寸就是 0。
  • 为了规避容器查询的局限性,使用一层额外的文本充当容器查询。
  • 使用另一层额外的文本来撑开最外层容器。

仅仅作为尝试,实际并不推荐,最终结构还是过于复杂,3份相同的内容有些过于冗余,其实HTML结构实现到右下角按钮那里就可以了,动态高度还是交给 JS去判断吧。d6G28资讯网——每日最新资讯28at.com

[1]容器查询: https://developer.mozilla.org/zh-CN/docs/Web/CSS/CSS_Container_Queries。d6G28资讯网——每日最新资讯28at.com

[2]CSS @container clamp (juejin.cn): https://code.juejin.cn/pen/7312418754502066214。d6G28资讯网——每日最新资讯28at.com

[3]CSS @container clamp (codepen.io): https://codepen.io/xboxyan/pen/oNmRbvR。d6G28资讯网——每日最新资讯28at.com

本文链接:http://www.28at.com/showinfo-26-48343-0.html尝试借助CSS @container实现多行文本展开收起

声明:本网页内容旨在传播知识,若有侵权等问题请及时与本网联系,我们将在第一时间删除处理。邮件:2376512515@qq.com

上一篇: 为什么不建议交付静态链接的可执行文件给用户?

下一篇: 使用 Sidecar CRD 优化 Istio 性能

标签:
  • 热门焦点
  • 一加Ace2 Pro官宣:普及16G内存 引领24G

    一加官方今天继续为本月发布的新机一加Ace2 Pro带来预热,公布了内存方面的信息。“淘汰 8GB ,12GB 起步,16GB 普及,24GB 引领,还有呢?#一加Ace2Pro#,2023 年 8 月,敬请期待。”同时
  • 一加Ace2 Pro真机揭晓 钛空灰配色质感拉满

    终于,在经过了几波预热之后,一加Ace2 Pro的外观真机图在网上出现了。还是博主数码闲聊站曝光的,这次的外观设计还是延续了一加11的方案,只是细节上有了调整,例如新加入了钛空灰
  • Mate60手机壳曝光 致敬自己的经典设计

    8月3日消息,今天下午博主数码闲聊站带来了华为Mate60的第三方手机壳图,可以让我们在真机发布之前看看这款华为全新旗舰的大致轮廓。从曝光的图片看,Mate 60背后摄像头面积依然
  • 8月总票房已突破10亿!《封神》第一:口碑已经成了

    8月5日消息,据灯塔专业版数据,截至8月5日9时35分,8月总票房(含预售)已突破10亿。其中,《封神》以大比分的优势领先。根据官方消息,目前该片总票房已经超过14.
  • 这款新兴工具平台,让你的电脑效率翻倍

    随着信息技术的发展,我们获取信息的渠道越来越多,但是处理信息的效率却成为一个瓶颈。于是各种工具应运而生,都在争相解决我们的工作效率问题。今天我要给大家介绍一款效率
  • 从零到英雄:高并发与性能优化的神奇之旅

    作者 | 波哥审校 | 重楼作为公司的架构师或者程序员,你是否曾经为公司的系统在面对高并发和性能瓶颈时感到手足无措或者焦头烂额呢?笔者在出道那会为此是吃尽了苦头的,不过也得
  • 华为Mate60标准版细节曝光:经典星环相机模组回归

    这段时间以来,关于华为新旗舰的爆料日渐密集。据此前多方爆料,今年华为将开始恢复一年双旗舰战略,除上半年推出的P60系列外,往年下半年的Mate系列也将
  • 电博会与软博会实现"线下+云端"的双线融合

    在本次“电博会”与“软博会”双展会利好条件的加持下,既可以发挥展会拉动人流、信息流、资金流实现快速交互流动的作用,继而推动区域经济良性发展;又可以聚
  • 中关村论坛11月25日开幕,15位诺奖级大咖将发表演讲

    11月18日,记者从2022中关村论坛新闻发布会上获悉,中关村论坛将于11月25至30日在京举行。本届中关村论坛由科学技术部、国家发展改革委、工业和信息化部、国务
Top