demo:

html:

<!DOCTYPE html>
<html lang="en"> <head>
<meta charset="UTF-8">
<meta name="author" content="guojufeng">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<meta http-equiv="X-UA-Compatible" content="ie=edge">
<title>兼容到ie7的自定义滚动条</title>
<link rel="stylesheet" href="scrollStyle.css">
</head> <body>
<div class="box" id="scrollBox">
<!-- 滚动条 -->
<div class="scrollBar-area" id="scrollBarBox">
<div class="scrollBar-bar" id="scrollBar"></div>
</div>
<ul class="scrollCont" id="scrollCont">
<li>
<span>滚动效果第一项</span>
</li>
<li>
<span>滚动效果第一项</span>
</li>
<li>
<span>滚动效果第一项</span>
</li>
<li>
<span>滚动效果第一项</span>
</li>
<li>
<span>滚动效果第一项</span>
</li>
<li>
<span>滚动效果第一项</span>
</li>
<li>
<span>滚动效果第一项</span>
</li>
<li>
<span>滚动效果第一项</span>
</li>
</ul>
</div>
<script src='http://libs.baidu.com/jquery/1.7.1/jquery.min.js'></script>
<script src="scrolldown.js"></script>
</body> </html>

css:

html.body,li,ul{
margin:;
padding:;
list-style: none;
}
body{
padding-top: 45px;
padding-left: 50px;
}
.box{
position: relative;
padding: 0px 11px;
background: #dbe0ff; width: 300px;
height: 180px;
overflow: hidden;
}
.scrollBar-area{
position: absolute;
/* 注意下边这种写法 */
top:;
bottom:;
/* top+bottom均为0,如果父元素height不为auto,就相当于height:100%的设置 */
/* 但是这种写法再ie5中用js得不到高度,jq的height()方法和js的clientHeight都得不到 */
right:;
width: 11px;
border-radius: 10px;
height: 100%;
}
.scrollBar-bar{
margin: 0 3px;
border-radius: 10px;
background: #b8c2ff;
cursor: pointer; /* 关键代码,提前定位好改变top值进行滚动 */
position: absolute;
top:;
right:;
z-index:;
left:; }
.scrollCont{
padding: 10px 0;
/* 关键代码,提前定位好改变top值进行滚动 */
position: absolute;
top:;
/* 注意下面这种写法 */
right:;
left:;
/* left+right均为0,如果父元素width不为0,就相当于块元素的width:100%的设置 */
}
li{
margin: 5px 0;
padding: 5px 10px;
cursor: pointer;
}
li:hover{
background: #a3b0ff;
}

js:

 var firefox = navigator.userAgent.indexOf('Firefox') != -1;//监测火狐浏览器下使用兼容写法
// 下拉滚动条
//竖向的滚动条,四个参数,可视区域ID,内容区域Id,滚动条区域,滚动条,
function ScrollTop(params){
var $container = $(params.scrollBox),//可视区域
$contanr = $(params.scrollCont),//内容区域
$conScroll = $(params.scrollBarBox),//滚动条活动区域
$sroll = $(params.scrollBar),//滚动条
startY = 0,//开始位置
lastY = 0,//结束位置
YN = false,//判断鼠标按下
bBtn = true;//判断滚动条上滚还是下滚
var $containerH = $container.height();
var $contanrH = $contanr.outerHeight();
// console.log($container.height())
// console.log($conScroll.height())
// console.log($contanr.outerHeight())
// console.log($container.height()*$conScroll.height()/$contanr.outerHeight())
function MouseScr(ev){
var $containerH1 = $container.height();
var $contanrH1 = $contanr.outerHeight();
if($containerH1 >= $contanrH1){
return false
}else{
var ev = ev || window.event,
TopY = 0;
if(ev.detail){
bBtn = ev.detail>0 ? true : false;
}
else{
bBtn = ev.wheelDelta<0 ? true : false;
}
if(bBtn){ //下
TopY = $contanr.position().top-10;
}
else{ //上
TopY = $contanr.position().top+10;
}
var maxTop = $contanr.outerHeight()-$container.outerHeight();
TopY = TopY > 0 ? 0 : TopY;
TopY = TopY < -maxTop ? -maxTop : TopY;
// console.log($conScroll.outerHeight());
$contanr.css({'top':TopY+'px'});
$sroll.css({'top':$sroll.height()*Math.abs(TopY)/$conScroll.height()+'px'}); if(ev.preventDefault){
ev.preventDefault();
}
else{
return false;
}
}
}
if( $containerH >= $contanrH){
// console.log('remove scroll')
$sroll.css('height',$containerH);
// 禁止鼠标事件
function MouseWheel(e) {
// console.log('we')
$contanr.css('top',0);
$sroll.css('top',0);
e = e || window.event;
if (e.stopPropagation) e.stopPropagation();
else e.cancelBubble = true;
if (e.preventDefault) e.preventDefault();
else e.returnValue = false;
return false;
};
if(firefox){
$contanr[0].removeEventListener('DOMMouseScroll',MouseScr,false);//兼容火狐。。。。。。。
$conScroll[0].removeEventListener('DOMMouseScroll',MouseScr,false);
}
// console.log($contanr)
// console.log($contanr[0])
$contanr[0].onmousewheel = MouseWheel;
$conScroll[0].onmousewheel = MouseWheel;
}else{
// 滚动条的高度等于可视区域高度*滚动区域高度/内容高度。
$sroll.css({'height':$container.height()*$conScroll.height()/$contanr.outerHeight()+'px'});
$sroll.mousedown(function(e){
startY = e.clientY - this.offsetTop;
this.setCapture && this.setCapture();//避免IE下拖拽过快鼠标失去对象
YN = true;
return false;
});
$sroll.mousemove(function(e){
var maxVal = $conScroll.height() - $(this).height();
if(YN){
lastY = e.clientY - startY;
lastY = lastY < 0 ? 0 :lastY;
lastY = lastY > maxVal ? maxVal : lastY; $(this).css({'top':lastY+'px'});
$contanr.css({'top':-$conScroll.height()*lastY/$(this).height()+'px'});
window.getSelection ? window.getSelection().removeAllRanges() : document.selection.empty(); // 防止拖动文本
e.stopPropagation();
} return false;
}); $sroll.mouseup(function(e){
YN = false;
NumY = lastY;
return false;
});
//为内容区域添加滑轮滚动事件
if($contanr[0].addEventListener){
$contanr[0].addEventListener('DOMMouseScroll',MouseScr,false);//兼容火狐。。。。。。。对,不是ie是火狐。
$conScroll[0].addEventListener('DOMMouseScroll',MouseScr,false);
}
$contanr[0].onmousewheel = MouseScr;
$conScroll[0].onmousewheel = MouseScr;
}
}
(function(){
var params = {
scrollBox : '#scrollBox',
scrollCont : '#scrollCont',
scrollBarBox : '#scrollBarBox',
scrollBar : '#scrollBar'
}
/*注意: .height()方法不计算padding在内 */
if($(scrollCont).height()>$(scrollBox).height()){
$(scrollBar).css('visibility','visible');
ScrollTop(params);
}else{
$(scrollBar).css('visibility','hidden');
}
})();

最新文章

  1. [计算机网络]简易http server程序
  2. C#使用ADO.NET访问数据库(一)
  3. for循环立即执行和不立即执行,js闭包
  4. HttpResponseMessage和HttpResponseException (转)
  5. jquery 获取form下的所有元素
  6. Java截图笔记
  7. PE刷题记录
  8. BZOJ3789 : 扫雪车
  9. 要点Java17 String
  10. 程序猿学英语—In July the English learning summary
  11. 全球多个 TOP 网站藏挖矿代码,5 亿 PC 沦为矿工
  12. 浅谈Trie树(字典树)
  13. java后台通过Servlet给用户发送手机短信验证码,第一次写勿喷,欢迎转载
  14. java使用SSH连接Linux系统
  15. Python利用pandas处理Excel数据的应用
  16. 2019嘉韦思杯线上初赛writeup
  17. Thing in java 第四章,控制执行流程,练习题答案
  18. Vue(四)之webpack和vue-cli
  19. vivado 创建PL工程
  20. hdoj 1874 畅通project续【SPFA】

热门文章

  1. 记一次艰难的IBM X3850重装系统和系统备份经验
  2. js 模拟鼠标事件
  3. 常用的js 总结
  4. mysql日期和字符相互转换
  5. u3d udp服务器
  6. iOS:当点击 FormSheet 之外时,关闭该视图
  7. 用外部物理路由器时与外部dhcp服务时怎样使用metadata服务(by quqi99)
  8. IP冲突解决方案
  9. springmvc+jquery实现省市区地址下拉框联动
  10. springmvc表单验证