全网整合营销服务商

电脑端+手机端+微信端=数据同步管理

免费咨询热线:400-708-3566

详解IE6中的position:fixed问题与随滚动条滚动的效果

详解IE6中的position:fixed问题与随滚动条滚动的效果

前言:

在《【jQuery】兼容IE6的滚动监听》(点击打开链接)提及到解决IE6fixed问题,具体是要引入一个js文件,还要声明一条脚本就为这个div声明fixed定位去解决,起始这样很不好啊。引入的Javascript不好管理之余,还要在head声明引入javascript,之后又要给这个div声明一个id,之后又要在脚本出弄一条声明,实在是烦死了。

使用position:fixed无非是想做出如下的效果。

基本上position:fixed是在IE7以上的所有浏览器都是没有问题的:

IE8:

野狐禅FireFox:

然而由于IE6中直接就没有position:fixed属性,要做出如下的效果:

只能利用position: absolute;加一段在css样式中执行的javascript脚本去解决。

<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01//EN" "http://www.w3.org/TR/html4/strict.dtd"> 
<html> 
  <head> 
    <meta http-equiv="Content-Type" content="text/html; charset=utf-8"> 
    <title>Untitled Document</title> 
    <style type="text/css">     
      .fixedbox { 
        background: #69C; 
        height: 60px; 
        width: 100px;         
        position: fixed; 
        bottom: 100px; 
        /*IE6实现position: fixed;*/ 
        /*等价于position: fixed;虽然代码好长,但是根本就不用管*/ 
        _position: absolute;         
        _top: expression(eval( 
        document.documentElement.scrollTop + document.documentElement.clientHeight-this.offsetHeight- 
        (parseInt(this.currentStyle.marginTop,10)||0)- 
        (parseInt(this.currentStyle.marginBottom,10)||0))); 
        /*等价于position: fixed;虽然代码好长,但是根本就不用管*/ 
        _margin-bottom:100px;/*设置位置,不要用bottom,而是改用margin-bottom,margin-xx来实现*/ 
      } 
    </style> 
  </head> 
  <body> 
    <div style="float:left;width:80%;min-height:100px;"> 
      <p>sss</p><p>sss</p><p>sss</p><p>sss</p><p>sss</p><p>sss</p><p>sss</p><p>sss</p><p>sss</p> 
      <p>sss</p><p>sss</p><p>sss</p><p>sss</p><p>sss</p><p>sss</p><p>sss</p><p>sss</p><p>sss</p> 
      <p>sss</p><p>sss</p><p>sss</p><p>sss</p><p>sss</p><p>sss</p><p>sss</p><p>sss</p><p>sss</p> 
      <p>sss</p><p>sss</p><p>sss</p><p>sss</p><p>sss</p><p>sss</p><p>sss</p><p>sss</p><p>sss</p>    
    </div> 
    <div style="float:left;width:20%;min-height:100px;"><div class="fixedbox"></div></div> 
    <div style="clear:both"></div>     
  </body> 
</html> 

上述代码,对于IE6的样式,前面都加上了_,_的部分是IE6特定的重写样式声明,具体见《【CSS】关于CSS样式中的!important、*、_符号》(点击打开链接)

而实际上,在IE6中,以下的CSS:

.fixed{ 
  position: absolute;        
  top: expression(eval( 
    document.documentElement.scrollTop + document.documentElement.clientHeight-this.offsetHeight- 
    (parseInt(this.currentStyle.marginTop,10)||0)- 
    (parseInt(this.currentStyle.marginBottom,10)||0))); 
} 

等价于其它浏览器的:

.fixed{ 
  position: fixed; 
} 

当然IE6中实现position:fixed的CSS可能在某些浏览器中不正常,因此在各个样式前面补上一条下划线_,表示仅在IE6中执行。

同时IE6应有的如上样式之后,不要像其它浏览器用right,top,left,bottom去定位,而是用margin-bottom,margin-left,margin-right去设置被position:fixed的div的位置,

这里调节div的位置的时候还需要注意,由于上述的兼容IE6的CSS利用到top的属性,所以设置margin-top是不管用,如果你要设置这个div在浮动的时候,离浏览器的顶部是多少的话,你应该这样写:

.fixed{ 
  /*IE6实现position: fixed;*/ 
  _position: absolute;         
  _top: expression(eval(document.documentElement.scrollTop)); 
  _margin-top:100px; 
} 

这里关于_top的代码之所以短了这么多,是因为无须用document.documentElement.clientHeight来获取浏览器显示窗口大小。

而-this.offsetHeight-(parseInt(this.currentStyle.marginTop,10)||0)-(parseInt(this.currentStyle.marginBottom,10)||0)一切是为了微调更加精确,如果你不想要也可以不加,仅仅是有一点视觉效果而已。

再者,上述的代码,大家可以看到,关于fixedbox这个东西,我并没有设置其right,left,是因为,我想让其在随滚动条滚动的时候,依旧能够保持父级div的float:left属性。

就是,右边的蓝*块,与左边一大堆sss,依旧是80%与20%的分割。

如有疑问请留言或者到本站社区交流讨论,感谢阅读,希望能帮助到大家,谢谢大家对本站的支持!


# IE6中的position:fixed与滚动问题  # IE6中的position:fixed的滚动效果  # JS 滚动事件window.onscroll与position:fixed写兼容IE6的回到顶部组件  # js完美解决IE6不支持position:fixed的bug  # ie6  # ie7  # ie8完美支持position:fixed的终极解决方案  # javascript ie6兼容position:fixed实现思路  # IE6支持position:fixed完美解决方法  # 是因为  # 又要  # 好长  # 滚动条  # 都是  # 我想  # 是在  # 你要  # 上了  # 如有  # 这么多  # 下划线  # 要在  # 要注意  # 希望能  # 要做  # 可以看到  # 仅仅是  # 好啊  # 重写 


相关文章: 高端建站三要素:定制模板、企业官网与响应式设计优化  实惠建站价格推荐:2025年高性价比自助建站套餐解析  武汉网站如何制作,黄黄高铁武穴北站途经哪些村庄?  建站之星如何开启自定义404页面避免用户流失?  建站之星后台密码遗忘?如何快速找回?  长沙做网站要多少钱,长沙国安网络怎么样?  建站与域名管理如何高效结合?  建站之星微信建站一键生成小程序+多端营销系统  网站制作难吗安全吗,做一个网站需要多久时间?  网页设计网站制作软件,microsoft office哪个可以创建网页?  如何快速登录WAP自助建站平台?  如何在建站宝盒中设置产品搜索功能?  如何用wdcp快速搭建高效网站?  如何访问已购建站主机并解决登录问题?  SQL查询语句优化的实用方法总结  建站之家VIP精选网站模板与SEO优化教程整合指南  如何快速生成ASP一键建站模板并优化安全性?  如何在万网ECS上快速搭建专属网站?  建站之星安装路径如何正确选择及配置?  黑客入侵网站服务器的常见手法有哪些?  如何通过山东自助建站平台快速注册域名?  建站之星如何取消后台验证码生成?  微信小程序 input输入框控件详解及实例(多种示例)  如何在IIS管理器中快速创建并配置网站?  如何用免费手机建站系统零基础打造专业网站?  如何选择美橙互联多站合一建站方案?  制作无缝贴图网站有哪些,3dmax无缝贴图怎么调?  网站制作的软件有哪些,制作微信公众号除了秀米还有哪些比较好用的平台?  陕西网站制作公司有哪些,陕西凌云电器有限公司官网?  如何在阿里云高效完成企业建站全流程?  简单实现Android文件上传  北京制作网站的公司排名,北京三快科技有限公司是做什么?北京三快科技?  PHP正则匹配日期和时间(时间戳转换)的实例代码  用v-html解决Vue.js渲染中html标签不被解析的问题  网站制作公司,橙子建站是合法的吗?  如何选择靠谱的建站公司加盟品牌?  建站之星图片链接生成指南:自助建站与智能设计教程  网站制作壁纸教程视频,电脑壁纸网站?  如何快速搭建高效WAP手机网站吸引移动用户?  广州网站建站公司选择指南:建站流程与SEO优化关键词解析  建站主机与服务器功能差异如何区分?  网站插件制作软件免费下载,网页视频怎么下到本地插件?  如何用好域名打造高点击率的自主建站?  中山网站制作网页,中山新生登记系统登记流程?  百度网页制作网站有哪些,谁能告诉我百度网站是怎么联系?  如何在IIS中配置站点IP、端口及主机头?  制作假网页,招聘网的薪资待遇,会有靠谱的吗?一面试又各种折扣?  制作门户网站的参考文献在哪,小说网站怎么建立?  高配服务器限时抢购:企业级配置与回收服务一站式优惠方案  微课制作网站有哪些,微课网怎么进? 

您的项目需求

*请认真填写需求信息,我们会在24小时内与您取得联系。