本示例使用Javascript實現了滾動頁面時,DIV到達頂部時固定在頂部。在IE下效果有點閃,效果網址:http:///keleyi/phtml/fixdiv.htm
下面是代碼:
<body style="margin:0px;">
<div style="height:300px;background:#e0e0e0"></div>
<div id="fixedMenu_keleyi_com" style="background:#ffffff;width:100%;"><ul><li><a
href="http:///menu/net/" target="_blank">.NET</a></li>
<li><a href="http:///menu/javascript/" target="_blank">Javascript</a></li>
<li><a href="http:///menu/jquery/" target="_blank">jQuery</a></li>
<li><a href="http:///menu/csharp/" target="_blank">C#</a></li>
<li><a href="http:///menu/other/" target="_blank">其他</a></li>
<li><a href="http:///" target="_blank">首頁</a></li></ul>
</div>
<div style="height:2600px;background:#999"></div>
<script type="text/javascript" src="http:///keleyi/pmedia/jquery-1.9.1.min.js"></script>
<script type="text/javascript">
$(function () {
var ie6 = document.all;
var dv = $('#fixedMenu_keleyi_com'), st;
dv.attr('otop', dv.offset().top); //存儲原來的距離頂部的距離
$(window).scroll(function () {
st = Math.max(document.body.scrollTop || document.documentElement.scrollTop);
if (st > parseInt(dv.attr('otop'))) {
if (ie6) {//IE6不支持fixed屬性,所以只能靠設置position為absolute和top實現此效果
dv.css({ position: 'absolute', top: st });
}
else if (dv.css('position') != 'fixed') dv.css({ 'position': 'fixed', top: 0 });
} else if (dv.css('position') != 'static') dv.css({ 'position': 'static' });
});
});
</script>
</body>
這個效果還有新版本的實現:http:///a/bjac/5d7f4ac2efa72d30.htm