资讯专栏INFORMATION COLUMN

overflow hidden 遇上absolute失效

刘明 / 2119人阅读

摘要:写了个由于页面并没有进行整体缩放,导致在小屏幕手机上显示会有异常。要求能够显示最后一个完整的标签。搜索解决方式时一直关注的是失效,而没有想过是因为使用了的影响。在解决问题的过程中,发现了另一种解决办法,在父元素上添加。

原文地址

背景

这几天开发的时候遇到了个问题,如图1。

写了个demo

由于页面并没有进行整体缩放,导致在小屏幕手机上显示会有异常。PM要求能够显示最后一个完整的标签。

当在iPhone5手机上查看页面的时候,由于设置了height以及overflow:hidden后面的标签被隐藏了。但是边框是用before伪元素实现的,并没有因为overflow:hidden 而一起隐藏(后面再探讨这种边框的不同实现方式)。

搜索解决方式时一直关注的是overflow:hidden失效,而没有想过是因为使用了transform的影响。

解决

网上搜到了一种解决方式:

在父元素上添加:transform-style:preserve-3d

试了下,果然好了,然而。。。换个手机,换个浏览器就不行了。这个属性存在兼容性问题。

那既然跟transform有关,试一下transform:translateZ(0),发现问题解决了,试了多个手机和浏览器,没有兼容性的问题。

在解决问题的过程中,发现了另一种解决办法,在父元素上添加position:relative。

这也就是说,是因为overflow:hidden失效了导致了这样的问题,而与是否使用了transform没有直接的关系(我把transform去掉,仍然有图1的问题,所以与transform并无必然联系,只能说使用transform可以解决问题)。

原因可以看这个文章 overflow:hidden失效

从这个角度进行分析的话,因为我们的before伪元素使用了absolute绝对定位,且外层没有定位,导致了这个before元素没有成功被隐藏,而相应的tag元素,由于没有设置定位,所以正常隐藏了。

那为什么使用了transform:translateZ(0)之后,问题也能够解决呢?

参考这个文章 transform对元素的影响

absolute绝对定位元素,如果含有overflow不为visible的父级元素,同时,该父级元素以及到该绝对定位元素之间任何嵌套元素都没有position为非static属性的声明,则overflow对该absolute元素不起作用。

这里涉及到层叠上下文的问题 可以参考 层叠上下文

当使用transform:translateZ(0)时,生成了新的层,覆盖在了上面。

文章版权归作者所有,未经允许请勿转载,若此文章存在违规行为,您可以联系管理员删除。

转载请注明本文地址:https://www.ucloud.cn/yun/113661.html

相关文章

  • overflow hidden 遇上absolute失效

    摘要:写了个由于页面并没有进行整体缩放,导致在小屏幕手机上显示会有异常。要求能够显示最后一个完整的标签。搜索解决方式时一直关注的是失效,而没有想过是因为使用了的影响。在解决问题的过程中,发现了另一种解决办法,在父元素上添加。 原文地址 背景 这几天开发的时候遇到了个问题,如图1。showImg(https://segmentfault.com/img/remote/1460000015922...

    lei___ 评论0 收藏0
  • overflow:hidden失效问题

    摘要:要求能够显示最后一个完整的标签。搜索解决方式时一直关注的是失效,而没有想过是因为使用了的影响。这个属性存在兼容性问题。在解决问题的过程中,发现了另一种解决办法,在父元素上添加。 2018-08-03 Questions about work 这几天开发的时候遇到了个问题,如图1。 写了个demo demo 地址 由于页面并没有进行整体缩放,导致在小屏幕手机上显示会有异常。PM要求能够显...

    YancyYe 评论0 收藏0
  • overflow:hidden失效问题

    摘要:要求能够显示最后一个完整的标签。搜索解决方式时一直关注的是失效,而没有想过是因为使用了的影响。这个属性存在兼容性问题。在解决问题的过程中,发现了另一种解决办法,在父元素上添加。 2018-08-03 Questions about work 这几天开发的时候遇到了个问题,如图1。 写了个demo demo 地址 由于页面并没有进行整体缩放,导致在小屏幕手机上显示会有异常。PM要求能够显...

    SHERlocked93 评论0 收藏0
  • 可视化效果(Visual effects)

    摘要:一般地,一个块盒的内容都被限制在该盒的边内。这种盒并不一定会根据其祖先的属性裁剪。默认情况下,元素不会被裁剪。在闭合路径内的内容会显示,而路径外边的都会被剪掉著作权归作者所有。 Overflow and clipping 一般地,一个块盒的内容都被限制在该盒的content边内。某些情况下,一个盒可能会溢出,意味着它的部分内容或者全部内容位于该盒外部,例如: 一行无法拆分,导致行盒比...

    JowayYoung 评论0 收藏0

发表评论

0条评论

刘明

|高级讲师

TA的文章

阅读更多
最新活动
阅读需要支付1元查看
<