html让一个元素固定位置不变,css如何让元素固定不变?

我们经常碰到的需求是希望页面某个元素固定在浏览器的一个位置,无论如何滚动滚动条,位置不变,就例如经常看到的弹出广告。方法一般是使用js控制,或者使用css。下面本篇文章给大家介绍一下CSS让元素固定不变的方法。

aca974b35c93c4a31f85a24bb52c25e0.png

在css中,可以利用position属性,设置position:fixed来让元素固定不变。

在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 值。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; /*必须*/

}

完整的代码: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;

}

更多CSS相关知识,可访问 CSS教程 !!

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值