`

css固定元素位置(fixed)

    博客分类:
  • web
css 
阅读更多

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

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

#ads{
    position:fixed;
    right:0;
    bottom:0;
    border:1px solid red;
    width: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{
    width:300px;
    height:250px;
    position:fixed;
    right:0;
    bottom:0;
    _position:absolute;
    _top:expression(documentElement.scrollTop + documentElement.clientHeight-this.offsetHeight);
    border:1px solid red;
}

 

分享到:
评论

相关推荐

    HTML5&CSS3网页制作:固定定位.pptx

    当position属性的取值为fixed时,即可将元素的定位模式设置为固定定位。 固定定位 示例 定位前 定位后 固定定位 示例 bottom : 0px right : 0px 在文档流中的位置没被保存 /*设置绝对定位*/ position: fixed; right:...

    css3 position fixed固定居中问题解决方案

    让此元素位置固定一般会添加position:fixed,但元素就不能居中了,fixed使对象脱离了正常文档流,解决方法如下

    固定-固定:CSS位置:固定限定符

    CSS固定位置在浏览器支持上差异很大,并且很难测试。 此存储库包含一个测试,该测试试图限定CSS position:fixed的应用程序。 它没有立即进行测试,而是等待用户滚动,这时它会检查以确定固定定位是否正常工作。 在...

    Web前端与移动开发之复合选择器 css元素显示模式 背景属性.txt

    2.css的元素显示模式 html元素一般分为块元素和行内元素 (1)块级元素 div p h1-h6 ul ol li ①独占一行 ②宽度 高度 外边距 内边距都可控制 ③宽度默认是容器(父级元素)100%的宽度 ④是一个容器及盒子 里面...

    css中postion的fixed与absolute区别详解

    fixed固定定位,参照位置是浏览器窗口的左上角,即坐标点为(0px, 0px) absolute绝对定位,参展位置是离当前元素最近的定位方式为fixed,absolute,relative的祖先原则的左上角,举个例子 复制代码代码如下:”p1″> ”...

    css锚点定位被顶部固定导航栏遮住的解决方案

    很多网站都有一个固定在上方的导航栏,方便用户搜索和跳转到其他页面。 同时为了方便用户浏览长文档,都会加上目录,点击段落标题跳转到段落所在的位置, 如图所示: 如果使用锚点实现目录的跳转会遇到 fixed 导航...

    让DIV块在页面的某个位置固定的css代码

    很高兴,我们在阅读了相关的注释后,我们大概能看到fixed是比较符合我们的需求的: fixed: 位置被设置为 fixed 的元素,可定位于相对于浏览器窗口的指定坐标。此元素的位置可通过 "left"、"top"、"right" 以及...

    《CSS设计彻底研究》光盘源码

     4.2.4 fixed(固定定位)   4.3 z-index空间位置   4.4 盒子的display属性   4.5 本章小结  第5章 文字与图像  …… 第 6章 链接与导航  第7章 竖直排列的导航菜单  第8章 水平导航菜单  第9章...

    css position 设置元素的定位方式详解

    1、定位元素(positioned element)是计算后位置属性分为: relative(相对)、absolute(绝对) 、 fixed(固定) 或 sticky (粘性)的元素。 2、top 、right、bottom、left属性指定定位元素的位置。 3、Z-index ...

    css设计彻底研究 源代码

    4.2.4 fixed(固定定位) 4.3 z-index空间位置 4.4 盒子的display属性 4.5 本章小结 第5章 文字与图像  …… 第6章 链接与导航 第7章 竖直排列的导航菜单 第8章 水平导航菜单 第9章 下拉菜单 第10...

    domv-popup:显示相对于“拥有”元素具有固定位置(弹出窗口)的 DOM 元素。 这是一个巧妙的解决方法,用于堆叠 CSS 中的上下文限制(z-index、overflow

    每个Popup实例都是一个简单的元素,具有固定的定位( position:fixed )。 此弹出窗口将相对于指定的owner元素定位。 如果所有者元素因任何原因(窗口调整大小、滚动、javascript 更改样式等)而改变位置,则弹出...

    css将div层固定显示在页面底部不随滚动条滚动

    复制代码代码如下:#totop{position:fixed;right:10px;bottom:10px;width:100px;height:100px;}

    《CSS设计彻底研究》【中文PDF+源代码】

    在《CSS设计彻底研究》中对设计中常用的网页元素和布局方式都给出详细的分类和归纳,并讲解了完整的解决方法,主要包括各种导航菜单(水平的、竖直的、固定宽度的、自适应宽度的、下拉的等),Tab面板、伸缩面板和...

    css入门笔记

    1.css的概述 1.问题 ... 2.fixed 固定 6.背景图片定位 作用:改变背景图片的位置 属性:background-position: 取值: 1.x y x: 背景图片水平偏移距离 取正向下右 取负向左 y: 背景图片...

    CSS Position(定位)

    元素的位置相对于浏览器窗口是固定位置。 即使窗口是滚动的它也不会移动: 实例 p.pos_fixed { position:fixed; top:30px; right:5px; }   注意: Fixed 定位在 IE7 和 IE8 下需要描述 !DOCTYPE 才能支持。 Fixed...

    JS实现随页面滚动显示/隐藏窗口固定位置元素

    窗口固定位置显示元素,当页面高度大于某高度,并且页面向下滚动时,显示该元素;当页面位置小于某高度,或者页面向上滚动时,隐藏... /*固定元素位置*/ top:2px; /*距顶端举例*/ right:40px; /*距右侧位置*/ color:red

    CSS实现导航固定的、左右滑动的滚动条制作方法

    菜单固定在顶部不动,使用 position:fixed; top:0; left:0;。同时要注意: 下面列表下移相应的位置,否则打开页面时,下方列表会被遮住一部分。 为菜单设置背景,否则透明的话,与下面列表滚动上来的内容会重叠...

    详解CSS粘性定位 sticky

    position:sticky这时的效果相当于fixed定位,固定到适当位置 讲 sticky 定位之前,我先说一下position 的其他定位, absolute: 生成绝对定位的元素,相对于 static 定位以外的第一个父元素进行定位。元素的 位置...

Global site tag (gtag.js) - Google Analytics