这几天开发的时候遇到了个问题,如图1。css
写了个demo demo 地址html
因为页面并无进行总体缩放,致使在小屏幕手机上显示会有异常。PM要求可以显示最后一个完整的标签。css3
当在iPhone5手机上查看页面的时候,因为设置了height
以及overflow:hidden
后面的标签被隐藏了。可是边框是用before伪元素实现的,并无由于overflow:hidden
而一块儿隐藏(后面再探讨这种边框的不一样实现方式)。git
搜索解决方式时一直关注的是overflow:hidden
失效,而没有想过是由于使用了transform
的影响。github
网上搜到了一种解决方式:浏览器
在父元素上添加:transform-style:preserve-3d
试了下,果真好了,然而。。。换个手机,换个浏览器就不行了。这个属性存在兼容性问题。wordpress
那既然跟transform
有关,试一下transform:translateZ(0)
,发现问题解决了,试了多个手机和浏览器,没有兼容性的问题。spa
在解决问题的过程当中,发现了另外一种解决办法,在父元素上添加position:relative
。这也就是说,是由于overflow:hidden
失效了致使了这样的问题,而与是否使用了transform
没有直接的关系(我把transform
去掉,仍然有图1的问题,只能说使用transform
能够解决问题)。3d
缘由能够看这个文章 overflow:hidden失效code
从这个角度进行分析的话,由于咱们的before
伪元素使用了absolute
绝对定位,且外层没有定位,致使了这个before
元素没有成功被隐藏,而相应的tag元素,因为没有设置定位,因此正常隐藏了。
那为何使用了transform:translateZ(0)
以后,问题也可以解决呢?
参考这个文章 transform对元素的影响
absolute绝对定位元素,若是含有overflow不为visible的父级元素,同时,该父级元素以及到该绝对定位元素之间任何嵌套元素都没有position为非static属性的声明,则overflow对该absolute元素不起做用。
这里涉及到层叠上下文的问题 能够参考 层叠上下文
当使用transform:translateZ(0)
时,生成了新的层,覆盖在了上面。
有的手机使用了transform以后仍然会出现上述问题,因此,更好的解决方式应该是设置position