如何使用flex布局保持内容不超出容器

  介绍

这篇文章主要介绍了如何使用flex布局保持内容不超出容器,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获、下面让小编带着大家一起了解一下。

移动端里面,flex布局很好用,它能够根据设备宽度来自动调整容器的宽度,但是最近在做项目的时候发现一个问题:

一个李里面设置了flex, flex: 0 0 33.333%,然后想让子元素里面的文字超出flex定义宽度后自动省略。

& lt; li>   ,,,& lt; https://www.yisu.com/zixun/a  href=" ">      

小米小米小米小米小米小米小米小米小米小米小米小米

     李 ul {   ,,,,显示:,flex;   }   李{   ,,,-webkit-box-flex:, 0;   ,,,-ms-flex:, 0, 0, 33.333%;   flex:,,,, 0, 0, 33.333%;   ,,,text-align:,中心;   ,,,填充:,0,1.333大众;   ,,,-webkit-box-sizing:, border-box;   ,,,box-sizing:, border-box;   ,,,margin-bottom:, 2.667大众;   }   li  p {   ,,,字体大小:,3.2大众;   ,,,颜色:,# 8 f8e94;   ,,,文本溢出:,省略;   ,,,白色空间:,nowrap;}   }

这时候会发现,p的文字可能会非常长,一些设备下需要隐藏显示,即不换行,并留下省略符,白马王子作标记。

这里会发现文本溢出:省略不生效,省略符根本没有出现。而且因为设置了nowrap会}发现文字会将内容撑开,导致内容超出了屏幕。所以必须要解决这个问题。

尝试取消父元素。李的flex: 0 0 33.33%,无效。

尝试取消ul容器的显示:flex,省略号出现。

因此猜测是flex布局的问题,进一步猜测省略符需要对父元素限定宽度。

尝试对父元素李设置宽度:100%无效,但是设置宽度:0可行。即:

李{   flex:,,,, 0, 0, 33.333%;   ,,,宽度:0   }

如果不设置宽度,李可以被子节点无限撑开,因此p总有足够的宽度在一行内显示所有文本,也就不能触发截断省略的效果。测试还有一种方法可以达到效果:

李{   flex:,,,, 0, 0, 33.333%;   ,,,溢出:,隐藏;   }

上面的二种方法都可以达到我们需要的效果,即给李设置了flex的值的时候,它会动态的获得父容器的剩余宽度,且不会被自己的子元素把内容撑开。

<李>

给html,身体设置max-width,元素似乎能强行撑开页宽;

<李>

给身体设置溢出,页宽不能被撑开了,但元素宽度还在,即元素本身还是溢出;

<李>

给html,身体同时设置max-width和溢出,页宽限定在max-width内,元素本身还是溢出;

<李>

给。主要的容器设置溢出:隐藏,同理.main是不溢出了,批评性思维本身还是溢出;

<李>

给批评性思维元素设置宽度或max-width,虽然宽度受限,但在特定宽度下省略符,白马王子显示不全,有时只显示两个点. .李

感谢你能够认真阅读完这篇文章,希望小编分享的“如何使用flex布局保持内容不超出容器”这篇文章对大家有帮助,同时也希望大家多多支持,关注行业资讯频道,更多相关知识等着你来学习!

如何使用flex布局保持内容不超出容器