您现在的位置是:网站首页> 编程资料编程资料
flex布局被子元素撑开如何保持内容不超出容器的方法flex布局实现左侧文字溢出省略右侧文字自适应详解flex实现左右布局中按钮溢出隐藏效果Flexbox 布局的最简单表单的实现详解flex多列布局遇到的问题和解决方案 css flex几种多列布局浅谈CSS3中display属性的Flex布局的方法
2021-09-03
1186人已围观
简介 这篇文章主要介绍了flex布局被子元素撑开如何保持内容不超出容器的方法,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
移动端里面,flex 布局很好用,它能够根据设备宽度来自动调整容器的宽度,但是最近在做项目的时候发现一个问题:
一个li里面设置了flex,flex: 0 0 33.333%,然后想让子元素里面的文字超出flex定义宽度后自动省略。
ul{ display: flex; } li{ -webkit-box-flex: 0; -ms-flex: 0 0 33.333%; flex: 0 0 33.333%; text-align: center; padding: 0 1.333vw; -webkit-box-sizing: border-box; box-sizing: border-box; margin-bottom: 2.667vw; } li p{ font-size: 3.2vw; color: #8F8E94; text-overflow: ellipsis; white-space: nowrap; } 这时候会发现,p的文字可能会非常长,一些设备下需要隐藏显示,即不换行,并留下省略符…作标记。
这里会发现text-overflow: ellipsis不生效,省略符根本没有出现。而且因为设置了 nowrap 会发现文字会将 content 撑开,导致内容超出了屏幕。所以必须要解决这个问题。
尝试取消父元素.li的flex: 0 0 33.33%,无效。
尝试取消ul容器的display: flex,省略号出现。
因此猜测是flex布局的问题,进一步猜测省略符需要对父元素限定宽度。
尝试对父元素li设置width: 100%无效,但是设置width: 0可行。即:
li{ flex: 0 0 33.333%; width: 0 } 如果不设置宽度,li可以被子节点无限撑开;因此p总有足够的宽度在一行内显示所有文本,也就不能触发截断省略的效果。测试还有一种方法可以达到效果:
li{ flex: 0 0 33.333%; overflow: hidden; } 上面的二种方法都可以达到我们需要的效果,即给 li 设置了 flex 的值 的时候,它会动态的获得父容器的剩余宽度,且不会被自己的子元素把内容撑开。
- 给html, body设置max-width,元素似乎能强行撑开页宽;
- 给body设置overflow,页宽不能被撑开了,但元素宽度还在,即元素本身还是溢出;
- 给html, body同时设置max-width和overflow,页宽限定在max-width内,元素本身还是溢出;
- 给.main容器设置overflow: hidden,同理.main是不溢出了,.notice本身还是溢出;
- 给.notice元素设置width或max-width,虽然宽度受限,但在特定宽度下省略符…显示不全,有时只显示两个点..
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。
相关内容
- CSS布局之如何实现居中布局CSS之居中布局的实现方法CSS布局奇淫技巧之--各种居中总结 CSS各种居中布局方法汇总CSS元素居中布局的简单方法CSS网页布局:div垂直居中的各种方法-CSS教程-网页制作-网页教学网CSS网页布局:div水平居中的各种方法-CSS教程-网页制作-网页教学网CSS高级技巧:网页布局-CSS教程-网页制作-网页教学网
- 三步用CSS写一个商城卡券利用css3径向渐变做一张优惠券的示例CSS实现优惠券边沿打孔效果
- css3实现蒙版弹幕功能前端实现弹幕效果的方法总结(包含css3和canvas的实现方式)CSS3 实现弹幕的示例代码
- 使用CSS实现黑暗模式和高亮模式的切换功能CSS中引用svg图片支持动态切换颜色的实现代码基于Css Variable的主题切换完美解决方案(推荐)详解如何简单实现CSS主题的切换纯css实现选中切换效果的示例纯CSS免费让网站拥有暗黑模式切换功能的实现代码
- CSS使用placeholder-shown伪类实现输入框浮动文字效果css浮动 float属性详解CSS实现元素浮动和清除浮动的方法纯CSS3+SVG实现的机器人悬浮动画效果源码html/css中float浮动的用法实例详解Css实现清除浮动的方法汇总什么是BFC? CSS 使用伪元素清除浮动的方法CSS3 清除浮动的方法示例CSS 清除浮动与BFC的方法
- css 权重值(层叠性)实例详解 CSS中选择器的权重值的计算浅谈CSS中的继承性,特殊性,层叠性和重要性
- 如何反转CSS中的贝塞尔曲线的实现方法CSS 曲线阴影实现的示例代码CSS3实现曲线阴影和翘边阴影
- CSS3中媒体查询结合rem布局适配手机屏幕纯js和CSS3媒体查询制作简单的响应式导航菜单特效源码详解CSS3 Media Queries中媒体属性的使用 CSS3媒体查询Media Queries基础学习教程使用CSS媒体查询(Media Queries)和JavaScript判断浏览器设备类型的方法CSS3媒体查询(Media Queries)介绍css3 响应式媒体查询的示例代码
- CSS Sticky Footer 几种实现方式
- css等高布局常用几种方式css多种方式实现等高布局的示例代码css设置多列等高布局的方法示例前端应该掌握的CSS实现多列等高布局技巧利用CSS3的flexbox实现水平垂直居中与三列等高布局浅析CSS等高布局的6种方式用CSS实现三列DIV等高布局以传达更好的视觉效果CSS 三栏等高布局实现方法CSS实例:三列等高布局-CSS教程-网页制作-网页教学网

