iframe在IE6下出现横向滚动条的解决方案

最近的项目中,遇到ie6下当iframe出现纵向滚动条时同时会出现横向滚动条。

分析了代码,大致的原因是iframe中的页面有相对body的样式包含width:100%的元素。

情况如下:

当出现纵向滚动条时,相对应的也出现了横向 滚动条。


解决方案一:给内页加上样式:html { overflow-y: scroll; }

注意:使用解决方案1带来的瑕疵是,当纵向内容部分高度没有超过屏幕时,仍然会出现不可用的纵向滚动条。


解决方案二:给内页加上样式:html { overflow-x: hidden; overflow-y: auto; }


当灰色的框的高度大于iframe的高度时仅出现纵向滚动条,但右边内容显示不完全(PS:里面文字内容是“这是个高为200px的div”),效果不正确。

当灰色的框的高度小于iframe的高度时没有滚动条出现,效果正确。


解决方案三:经过了多次尝试仍然没有发现纯css的完美解决方案,而我们追求的是最完美的效果。既然纯css解决不了,我们只好搬出js来了,通过前面的测试我们发现灰色框高度小于iframe的高度时不需要做任何处理效果正确,而灰色框高度大于iframe的高度时方案一是完美的。于是,我们的js有如下思路:当浏览器为IE6且内容高度比iframe高时给html标签加入方案一的样式。下面是jQuery的代码:(不用jQuery的话思路一样。)

$(function(){
    if($.browser.msie&&$.browser.version=="6.0"&&$("html")[0].scrollHeight>$("html").height())
        $("html").css("overflowY","scroll");
});

灰色的框的高度大于iframe的高度时仅出现纵向滚动条,效果正确。

当灰色的框的高度小于iframe的高度时效果正确。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值