relative相对定位实现—侧边栏固定

relative相对定位实现—侧边栏固定

问题:

1 什么事件? 2 什么时候发生时间? 3 事件函数什么?

思路:滚动条事件;在一定滚动范围内发生;让其重新定位。

思路:

1 添加滚动条事件:
window.οnscrοll=function(){}

2 求出滚动范围:

当滚动高度:scrollHeight>侧边栏据浏览器上方的距离150px且scrollHeight<中间高度-侧边高度+侧边据浏览器的高度;

3 事件函数:

重新定位:position:relative;top:'scrollHeight-150px';left:'0px';

为什么top值为scrollHeight-150px?

相对定位是相对于自己本身原来应该在的位置,当滚动条滚到左侧边栏时若不设置相对定位应该会随着鼠标下拉,侧边栏一直向上逐渐消失,设置了相对定位,想要相对与原来的位置保持某个高度不变,明显必须top越来越大,因为原来的位置是一直向上的,top值等于滚动到左侧边栏时,此时鼠标再往下滑的距离 = 鼠标总下滑的距离(scrollHeight)-左侧边栏距距离最上面的距离(150px)

bug:当scrollHeight<侧边栏据浏览器上方的距离或scrollHeight>中间高度-侧边高度+侧边据浏览器的高度

强行到顶或到底,出现原因是滚动过快。

ps:侧边栏必须先设置相对定位

html:

<!DOCTYPE html>
<html>
<head>
	<meta charset="utf-8">
	<title>侧边栏固定</title>
	<link rel="stylesheet" type="text/css" href="index.css">
	<script type="text/javascript" src="index.js"></script>
</head>
<body>
<div id="header"></div>
<div id="containter">
	<div id="left">导航栏</div>
	<div id="main">内容区</div>
	<div id="right">侧边栏</div>
</div>
<div id="footer"></div>
</body>
</html>

css:

*{
	padding:0;
	margin: 0;
}
#header{
	background: #333;
	height: 100px;
}
#containter{
	overflow: hidden;
	margin: 50px 0 0 100px;
}
#left{
	background: #ccc;
	margin-right: 100px;
	width: 300px;
	height: 400px;
	float:left;
}
#main{
	background: #666;
	margin-right: 100px;
	width: 400px;
	height: 1000px;
	float:left;
}
#right{
	background: #999;
	width: 200px;
	height: 400px;
	float:left;
}
#footer{
	background: blue;
	height: 100px;
	clear: both;
	margin-top: 150px;
}

javascript:

window.οnlοad=function(){
	var left=document.getElementById('left');
	var main=document.getElementById('main');
	var contentheight=main.offsetHeight-left.offsetHeight;
	window.οnscrοll=function(){
		var scrollHeight=document.documentElement.scrollTop;
		if(scrollHeight>150&&scrollHeight<contentheight+150){
			left.style.position='relative';
			left.style.left='0px';
			left.style.top=scrollHeight-150+'px';
		}else if(scrollHeight<=150){
			left.style.position='relative';
			left.style.left='0px';
			left.style.top='0px';
		}else{
			left.style.position='relative';
			left.style.left='0px';
			left.style.top=scrollHeight-150+'px';
		}
	}
}

图示:

d
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值