分享

IE6,IE7下设置body{overflow:hidden;}失效Bug

 novo_land 2011-09-14

译+整理]IE6,IE7下设置body{overflow:hidden;}失效Bug

05.01.2011, Bug修复前端技术边译边学, by 飞长.

参考文章:http:///css/Document-Scrollbars-Overflow-Inconsistency

此项其实并不是Bug,只是各浏览器默认付值不同造成的,其他明智的浏览器还好,这个bug只出现在IE6 IE7下

 

问题重现:

<p>There are no scrollbars on this page in sane browsers</p>
html, body, p {
    margin: 0;
    padding: 0;
}

body {
    overflow: hidden;
}

p {
    width: 5000px;
    height: 5000px;
}

IE6 IE7下不生效(IE6下横向纵向滚动条都在 IE7下纵向滚动条还在)

原因:

明智的浏览器(ex. chrome and firefox)会初始付值给html{overflow:visible;}

IE6 初始付值html{overflow-x:auto;overflow-y:scroll;}

IE7 初始付值html{overflow-x:visible;overflow-y:scroll;}

只有dom根结点(也就是html根节点)设置html{overflow:visible;}的时候,浏览器才会将body元素中的overflow值应用到视图区。

这样就很明了啦,并不是bug,而是浏览器初始值不同产生的问题。

 

解决办法:

html, body, p {
    margin: 0;
    padding: 0;
}

html {
    overflow: visible;
}

body {
    overflow: hidden;
}

p {
    width: 5000px;
    height: 5000px;
}

    本站是提供个人知识管理的网络存储空间,所有内容均由用户发布,不代表本站观点。请注意甄别内容中的联系方式、诱导购买等信息,谨防诈骗。如发现有害或侵权内容,请点击一键举报。
    转藏 分享 献花(0

    0条评论

    发表

    请遵守用户 评论公约

    类似文章 更多