zoukankan      html  css  js  c++  java
  • css固定元素位置(fixed)

    来源:http://www.cnblogs.com/lecaf/archive/2011/03/25/fixed.html

    fixed是一种特殊的absolute,同样不占文档流,特殊的地方在于fixed定位的参照系始终是浏览器窗口,而absoute定位的参照系是已经定位的最近父容器。

    我们经常碰到的需求是希望页面某个元素固定在浏览器的一个位置,无论如何滚动滚动条,位置不变,就例如经常看到的弹出广告。方法一般是使用js控制,或者使用css。这里我写的是css的控制方法。

    在IE7以上版本及firefox、opera、safari里,都支持css属性"position:fixed",它的作用就是将元素相对于窗口固定位置。代码如下

    复制代码
    #ads{
        position:fixed;
        right:0;
        bottom:0;
        border:1px solid red;
        300px;
        height:250px;
    }
    复制代码

    我们定义一个#ads的id样式,并给他设了高度宽度,通过position:fixed以及right、bottom将元素定位在窗口右下角。

    但是在IE6下,并不支持position:fixed属性,这个时候我们需要对IE6进行hack处理。解决的方案是使用postion:absolute属性,它的作用大家都很熟悉,相对于父元素进行绝对定位,然后我们可以通过expression来改变#ads的top值。

    PS expression的定义:IE5及其以后版本支持在CSS中使用expression,用来把CSS属性和Javas cript表达式关联起来,这里的CSS属性可以是元素固有的属性,也可以是自定义属性。就是说CSS属性后面可以是一段Javas cript表达式,CSS属性的值等于Javas cript表达式计算的结果。 在表达式中可以直接引用元素自身的属性和方法,也可以使用其他浏览器对象。这个表达式就好像是在这个元素的一个成员函数中一样。

    所以我们可以通过在css里计算javascript值来改变top值,代码如下:

    #ads{
        _position:absolute;
        _top:expression(documentElement.scrollTop + documentElement.clientHeight-this.offsetHeight);
    }

    似乎一切都完美了,但是我们在IE6下运行的时候会发现,随着滚动条的移动,我们的这个#ads朋友他会抖动。解决方法也很简单,只要在body里加一点点的css,如下:

    body{
        background-image:url(about:blank); /* for IE6 */ 
        background-attachment:fixed; /*必须*/
    }

    好啦,完工!!!!!!!!!!!!!!!!!!!!!!!!

    有木有!!!!!!!!!!!!!!!!!!!!!!!!

    PS:原本使用的是"url(text.txt)",但是txt这个是不存在的,http请求报404错误,导致影响加载速度,参考了网上的一些写法,使用about:blank可以达到相同目的。

    原理据说是ie6不支持fixed 而其样式背景却支持fixed,通过背景来此消彼长消除抖动,望大牛指教。

    完整的代码:

    复制代码
    body{
        background-image:url(about:blank); /* for IE6 */ 
        background-attachment:fixed; /*必须*/
    }
    #ads{
        300px;
        height:250px;
        position:fixed;
        right:0;
        bottom:0;
        _position:absolute;
        _top:expression(documentElement.scrollTop + documentElement.clientHeight-this.offsetHeight);
        border:1px solid red;
    }
    复制代码

    转载请注明出处:http://www.cnblogs.com/lecaf/

    如有任何建议或疑问,欢迎留言讨论。

    如果觉得文章不错的话,欢迎点一下右下角的推荐。

  • 相关阅读:
    HTML5 postMessage 和 onmessage API 详细应用
    layerX
    HTML5中createPattern()
    HTML5中lineCap端点样式遇到closePath()
    [转]Modernizr的介绍和使用
    HTML5学习之路
    javascript选取文档元素
    ie不支持getElementsByClassName的解决办法
    document.images、document.forms、doucument.links——>HTMLCollection
    JavaScript 参考手册——javascript本地和内置对象、BOM、DOM
  • 原文地址:https://www.cnblogs.com/cblx/p/5084583.html
Copyright © 2011-2022 走看看