这篇文章主要介绍了如何使用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布局保持内容不超出容器”这篇文章对大家有帮助,同时也希望大家多多支持,关注行业资讯频道,更多相关知识等着你来学习!