基于jquery的滚动条滚动固定div(附演示下载)
时间:2021-03-10 09:23:26|栏目:jquery|点击: 次
例如:淘宝商品详情里,滚动条往下来拉的时候,商品详情和评价那个nav会固定,现在很多网站也都有这样类似的效果,现在流行这个么?元芳,你怎么看?我也在网上找了找代码,屡试不爽啊,很多代码乱且没用。于是乎,我自己写一个,代码非常之简单,只有10几行,但遗憾的是,不兼容IE6,如果谁有兼容IE6的例子,还请指教。
直接贴下代码吧。
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=gb2312">
<title>demo</title>
<script src="jquery-1.4.1.min.js" type="text/javascript"></script>
<script type="text/javascript">
$(document).ready(function(){
var loaded = true;
var top = $("#demo").offset().top;
function Add_Data()
{
var scrolla=$(window).scrollTop();
var cha=parseInt(top)-parseInt( scrolla);
if(loaded && cha<=0)
{
$("#demo").removeClass("demo2").addClass("demo1");
$("#demo").html("我现在是蓝色,把滚动条往上拉我会显示成红色。我已经固定了。");
loaded=false;
}
if(!loaded && cha>0)
{
$("#demo").removeClass("demo1").addClass("demo2");
$("#demo").html("我现在是红色,把滚动条往下拉我会显示成蓝色。我还没固定了。");
loaded=true;
}
}
$(window).scroll(Add_Data);
});
</script>
<style type="text/css">
.demo
{
border: 1px solid #dcdcdc;
width: 300px;
margin-top: 10px;
overflow: auto;
text-align: left;
background-color: #ffffff;
height:200px;
}
.demo1
{
position: fixed;
_position: absolute;
top: 0px;
background-color: #0000ff;
height:200px;
width:300px;
color:#ffffff;
}
.demo2
{
border: 1px solid #dcdcdc;
width: 300px;
margin-top: 10px;
overflow: auto;
text-align: left;
background-color: #ff0000;
height:200px;
color:#ffffff;
}
</style>
</head>
<body>
<div class="demo">
</div>
<div class="demo">
</div>
<div class="demo">
</div>
<div class="demo">
</div>
<div class="demo2" id="demo">
我现在是红色,把滚动条往下啦我会显示成蓝色。我还没固定了。
</div>
<div class="demo">
</div>
<div class="demo">
</div>
<div class="demo">
</div>
<div class="demo">
</div>
<div class="demo">
</div>
</body>
</html>
友情提醒:我只提供了一个简单的Demo,在实际开发中Demo中的东西还是需要修改修改的。
在线演示:http://demo.jb51.net/js/2012/scrollfixed/
附:Demo下载
直接贴下代码吧。
复制代码 代码如下:
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=gb2312">
<title>demo</title>
<script src="jquery-1.4.1.min.js" type="text/javascript"></script>
<script type="text/javascript">
$(document).ready(function(){
var loaded = true;
var top = $("#demo").offset().top;
function Add_Data()
{
var scrolla=$(window).scrollTop();
var cha=parseInt(top)-parseInt( scrolla);
if(loaded && cha<=0)
{
$("#demo").removeClass("demo2").addClass("demo1");
$("#demo").html("我现在是蓝色,把滚动条往上拉我会显示成红色。我已经固定了。");
loaded=false;
}
if(!loaded && cha>0)
{
$("#demo").removeClass("demo1").addClass("demo2");
$("#demo").html("我现在是红色,把滚动条往下拉我会显示成蓝色。我还没固定了。");
loaded=true;
}
}
$(window).scroll(Add_Data);
});
</script>
<style type="text/css">
.demo
{
border: 1px solid #dcdcdc;
width: 300px;
margin-top: 10px;
overflow: auto;
text-align: left;
background-color: #ffffff;
height:200px;
}
.demo1
{
position: fixed;
_position: absolute;
top: 0px;
background-color: #0000ff;
height:200px;
width:300px;
color:#ffffff;
}
.demo2
{
border: 1px solid #dcdcdc;
width: 300px;
margin-top: 10px;
overflow: auto;
text-align: left;
background-color: #ff0000;
height:200px;
color:#ffffff;
}
</style>
</head>
<body>
<div class="demo">
</div>
<div class="demo">
</div>
<div class="demo">
</div>
<div class="demo">
</div>
<div class="demo2" id="demo">
我现在是红色,把滚动条往下啦我会显示成蓝色。我还没固定了。
</div>
<div class="demo">
</div>
<div class="demo">
</div>
<div class="demo">
</div>
<div class="demo">
</div>
<div class="demo">
</div>
</body>
</html>
友情提醒:我只提供了一个简单的Demo,在实际开发中Demo中的东西还是需要修改修改的。
在线演示:http://demo.jb51.net/js/2012/scrollfixed/
附:Demo下载
上一篇:JQuyer $.post 与 $.ajax 访问WCF ajax service 时的问题需要注意的地方
栏 目:jquery
本文标题:基于jquery的滚动条滚动固定div(附演示下载)
本文地址:http://www.codeinn.net/misctech/77647.html