Tag标签 | 收藏本站 | 设为首页 | 参考书籍 | web前端技术交流①群:WEB前端技术交流群 会员登录 | 会员注册

首页文字描述

会员投稿 RSS订阅 专注web前端: 要么读书、要么旅行,身体和精神必须要有一个在路上。【每天一小步,成功一大步】
搜索: 您的位置主页 > WEB前端 > Bug解决 > IE6,IE7中body{overflow:hidden;}失效BUG解决
隐藏/显示侧边栏

IE6,IE7中body{overflow:hidden;}失效BUG解决

2013-11-19 15:19    来源:未知    责任编辑:admin    字号【
此项其实并不是Bug,只是各浏览器默认付值不同造成的,其他明智的浏览器还好,这个bug只出现在IE6 IE7下

问题所在:

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值应用到视图区。

举个例子说:

设置了body{overflow:hidden},还会出现滚动条,不过这个滚动条不是body的,是html的
只有你设置html{overflow:visible;} body{overflow的值}才能传递到html{}中去
这样html的值就变成了{overflow:hidden},ok没有滚动条了

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

解决办法:

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

html {
    overflow: visible;
}

body {
    overflow: hidden;
}

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

此项可以整理到自己的reset.css文件中去。

雅虎reset.css初始化脚本

更多
Tags 标签:
责任编辑:admin
最新图文列表
整合、复习所有CSS的兼容BUG(IE6、7、8,Firefox,Chrome)
整合、复习所有
设为首页 | 加入收藏 | 关于我们| 版权声明 | 在线留言 | 网站地图 |