ios下overflow:hidden 无效

ios下overflow:hidden 无效原因及解决方案

在ipad和ios上设置overflow:hidden不起作用,目前网上找到的方法是给父级元素添加position:fixed,比如这样:

body {
    height: 100%;
    overflow: hidden;
    width: 100%;
    position: fixed;
    }

原因暂时还没想清楚,网上也没有针对这方面的具体解释,等找到了回头来更新


在Stack Overflow上找到了大概的原因,翻译如下:

overflow的实现原理:

  1. 整个viewportoverflow是由html中的overflow来决定的;

  2. 假如你不去设置htmloverflow(也就是默认的visible属性),而去设置bodyoverflow:hidden,也是可以的;

  3. 假如你设置了htmloverflow属性的值(除去默认的visible),那么bodyoverflow属性就不会生效了

     /*body的overflow设置无效*/
     html{overflow: hidden;}
     body{overflow: scroll;}
    

上面的几点在大部分的现代浏览器里都是成立的,但ios下的除外,包括iphone和ipad

ios认为(玛德,标准制定者就是任性),网页内容是个整体,需要将所有的都显示出来,所有overflow就不该起作用,这是他们刻意的,不是bug,而且在更高版本的ios7,8,9中也是这样设定的(mmp).

对viewport我们没法改变,但是我们可以通过改变body自身的overflow:

  • 改变html的overflow默认属性(visible)为auto或者hidden,哪个都行,对后面的效果都是一致的,这样body就不会继承viewport的overflow属性,然后通过设置body的overflow:hidden,大部分的溢出内容就会被隐藏掉
  • 不过设置了position:absolute的除外,因为它默认是相对viewport进行绝对定位的,这个时候你要对body进行设置position:relative

总结起来一句话,body的范围要比viewport的范围要大,这样才能使body的overflow生效

达到这个效果:

  • body需要设置viewport的宽高:body{width:100%;height:100%}
  • html和body的padding,margin都不能有;html的border也不能有
  • 给body加上box-sizing: border-box,解决padding的问题(这里没咋看懂,把原文贴一下:Finally, in order to deal with body padding, and in case you ever want to set a border on the body, make the math work with box-sizing: border-box for the body.)

最后的代码整理如下:

html {
  overflow: hidden;
  height: 100%;
  margin: 0;
  padding: 0;
  border: none;
}

body {
  overflow: hidden;
  position: relative;
  box-sizing: border-box;
  margin: 0;
  height: 100%;
}

over!

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 问答题47 /72 常见浏览器兼容性问题与解决方案? 参考答案 (1)浏览器兼容问题一:不同浏览器的标签默认的外补...
    _Yfling阅读 14,681评论 1 92
  • 选择qi:是表达式 标签选择器 类选择器 属性选择器 继承属性: color,font,text-align,li...
    love2013阅读 6,831评论 0 11
  • 1标准的CSS的盒子模型?与低版本IE的盒子模型有什么不同的? CSS盒子模型:由四个属性组成的外边距(margi...
    秦小婕阅读 4,933评论 0 1
  • 云联是典型的骗子公司、传销公司啊,别以为你换了马甲就不认识你 我来逐条批驳。不服来辩 1、2016贵阳国际大数据博...
    我爱你如鲸向海阅读 1,332评论 0 0