亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 編程 > JavaScript > 正文

基于JavaScript實現自定義滾動條

2019-11-19 17:47:00
字體:
來源:轉載
供稿:網友

可直接使用的js滾動條,先看看效果圖:

代碼如下

<!DOCTYPE html><html lang="en"><head> <meta charset="UTF-8"> <title>自定義滾動條</title></head><meta http-equiv="Content-Type" content="text/html; charset=utf-8" /><title>滾動條</title><style type="text/css">*{ margin:0; padding:0;}#mainBox{  width:400px;  height:500px;  border:1px #bbb solid;  position:relative;  overflow:hidden;  margin:50px auto; }#content{  height:2500px;  position:absolute;  left:0;  top:0;  background:url(https://timgsa.baidu.com/timg?image&quality=80&size=b9999_10000&sec=1485320653275&di=b7bc29cc2c7b3388d44958d8f97db0a3&imgtype=0&src=http%3A%2F%2Fphotocdn.sohu.com%2F20151212%2Fmp48094209_1449905365456_7.jpg) }.scrollDiv{ width:18px;  position:absolute;  top:0;  background:#666; border-radius:10px;}</style></head><body><div id="mainBox"> <div id="content"></div></div><script type="text/javascript">var doc=document;var _wheelData=-1;var mainBox=doc.getElementById('mainBox');function bind(obj,type,handler){ var node=typeof obj=="string"?$(obj):obj; if(node.addEventListener){ node.addEventListener(type,handler,false); }else if(node.attachEvent){ node.attachEvent('on'+type,handler); }else{ node['on'+type]=handler; }}function mouseWheel(obj,handler){ var node=typeof obj=="string"?$(obj):obj; bind(node,'mousewheel',function(event){ var data=-getWheelData(event); handler(data); if(document.all){ window.event.returnValue=false; }else{ event.preventDefault(); } }); //火狐 bind(node,'DOMMouseScroll',function(event){ var data=getWheelData(event); handler(data); event.preventDefault(); }); function getWheelData(event){ var e=event||window.event; return e.wheelDelta?e.wheelDelta:e.detail*40; }}function addScroll(){ this.init.apply(this,arguments);}addScroll.prototype={ init:function(mainBox,contentBox,className){ var mainBox=doc.getElementById(mainBox); var contentBox=doc.getElementById(contentBox); var scrollDiv=this._createScroll(mainBox,className); this._resizeScorll(scrollDiv,mainBox,contentBox); this._tragScroll(scrollDiv,mainBox,contentBox); this._wheelChange(scrollDiv,mainBox,contentBox); this._clickScroll(scrollDiv,mainBox,contentBox); }, //創建滾動條 _createScroll:function(mainBox,className){ var _scrollBox=doc.createElement('div') var _scroll=doc.createElement('div'); var span=doc.createElement('span'); _scrollBox.appendChild(_scroll); _scroll.appendChild(span); _scroll.className=className; mainBox.appendChild(_scrollBox); return _scroll; }, //調整滾動條 _resizeScorll:function(element,mainBox,contentBox){ var p=element.parentNode; var conHeight=contentBox.offsetHeight; var _width=mainBox.clientWidth; var _height=mainBox.clientHeight; var _scrollWidth=element.offsetWidth; var _left=_width-_scrollWidth; p.style.width=_scrollWidth+"px"; p.style.height=_height+"px"; p.style.left=_left+"px"; p.style.position="absolute"; p.style.background="#ccc"; contentBox.style.width=(mainBox.offsetWidth-_scrollWidth)+"px"; var _scrollHeight=parseInt(_height*(_height/conHeight)); if(_scrollHeight>=mainBox.clientHeight){ element.parentNode.style.display="none"; } element.style.height=_scrollHeight+"px"; }, //拖動滾動條 _tragScroll:function(element,mainBox,contentBox){ var mainHeight=mainBox.clientHeight; element.onmousedown=function(event){ var _this=this; var _scrollTop=element.offsetTop; var e=event||window.event; var top=e.clientY; //this.onmousemove=scrollGo; document.onmousemove=scrollGo; document.onmouseup=function(event){ this.onmousemove=null; } function scrollGo(event){ var e=event||window.event; var _top=e.clientY; var _t=_top-top+_scrollTop; if(_t>(mainHeight-element.offsetHeight)){  _t=mainHeight-element.offsetHeight; } if(_t<=0){  _t=0; } element.style.top=_t+"px"; contentBox.style.top=-_t*(contentBox.offsetHeight/mainBox.offsetHeight)+"px"; _wheelData=_t; } } element.onmouseover=function(){ this.style.background="#444";  } element.onmouseout=function(){ this.style.background="#666";  } }, //鼠標滾輪滾動,滾動條滾動 _wheelChange:function(element,mainBox,contentBox){ var node=typeof mainBox=="string"?$(mainBox):mainBox; var flag=0,rate=0,wheelFlag=0; if(node){ mouseWheel(node,function(data){ wheelFlag+=data; if(_wheelData>=0){  flag=_wheelData;  element.style.top=flag+"px";  wheelFlag=_wheelData*12;  _wheelData=-1; }else{  flag=wheelFlag/12; } if(flag<=0){  flag=0;  wheelFlag=0; } if(flag>=(mainBox.offsetHeight-element.offsetHeight)){  flag=(mainBox.clientHeight-element.offsetHeight);  wheelFlag=(mainBox.clientHeight-element.offsetHeight)*12; } element.style.top=flag+"px"; contentBox.style.top=-flag*(contentBox.offsetHeight/mainBox.offsetHeight)+"px"; }); } }, _clickScroll:function(element,mainBox,contentBox){ var p=element.parentNode; p.onclick=function(event){ var e=event||window.event; var t=e.target||e.srcElement; var sTop=document.documentElement.scrollTop>0?document.documentElement.scrollTop:document.body.scrollTop; var top=mainBox.offsetTop; var _top=e.clientY+sTop-top-element.offsetHeight/2; if(_top<=0){ _top=0; } if(_top>=(mainBox.clientHeight-element.offsetHeight)){ _top=mainBox.clientHeight-element.offsetHeight; } if(t!=element){ element.style.top=_top+"px"; contentBox.style.top=-_top*(contentBox.offsetHeight/mainBox.offsetHeight)+"px"; _wheelData=_top; } } }}new addScroll('mainBox','content','scrollDiv');</script></body></html>

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持武林網。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
久久久999成人| 国产精品一区二区三区久久久| 久久亚洲国产精品成人av秋霞| 国产精品亚洲一区二区三区| 98精品国产自产在线观看| 久久青草福利网站| 国产日产欧美精品| 5566成人精品视频免费| 中文字幕欧美日韩在线| 国产精品69久久| 亚洲精品日韩久久久| 精品国产区一区二区三区在线观看| 国产精品丝袜久久久久久不卡| 国产精品啪视频| 国产视频精品自拍| 亚洲精品国产品国语在线| 亚洲美女中文字幕| 亚洲国产成人av在线| 欧美极品少妇与黑人| 亚洲欧美日韩另类| 欧美国产高跟鞋裸体秀xxxhd| 中文字幕一精品亚洲无线一区| 欧美性xxxx18| 日韩精品www| 久久久久亚洲精品成人网小说| 国产亚洲精品激情久久| 亚洲国产第一页| 国产黑人绿帽在线第一区| 中文字幕日本精品| 日韩中文字幕免费| 日韩毛片在线看| 日韩国产一区三区| 久久久久国产一区二区三区| 久久久女女女女999久久| 久久久影视精品| 成人亚洲综合色就1024| 51精品国产黑色丝袜高跟鞋| 中文字幕日韩视频| 好吊成人免视频| 日韩精品欧美国产精品忘忧草| 国产亚洲精品成人av久久ww| 日韩专区中文字幕| 国产91精品久久久久| 国产欧美欧洲在线观看| 国产91在线高潮白浆在线观看| 日韩小视频在线| 国产精品一区二区久久国产| 97成人精品视频在线观看| 国色天香2019中文字幕在线观看| 国产suv精品一区二区| 日韩国产欧美精品一区二区三区| 国产精品日韩在线观看| 一色桃子一区二区| 日韩av最新在线观看| 亚洲精品久久久久中文字幕二区| 国产日韩中文在线| 亚洲欧美成人一区二区在线电影| 最近2019中文字幕第三页视频| 欧美大片在线看| 97精品国产aⅴ7777| 热久久这里只有| 国产精品吹潮在线观看| 国产精品久久久久久五月尺| 国模私拍一区二区三区| 国产精品普通话| 成人免费观看网址| 国产91亚洲精品| 国产主播精品在线| 国产免费一区二区三区在线观看| 午夜精品免费视频| 国产一区二区三区在线看| 92福利视频午夜1000合集在线观看| 国产在线98福利播放视频| 久久青草精品视频免费观看| 精品国产区一区二区三区在线观看| 欧美电影在线观看完整版| 久久国产精品久久久久久| 夜夜嗨av色综合久久久综合网| 6080yy精品一区二区三区| 亚洲免费视频在线观看| 美女av一区二区三区| 亚洲电影免费观看高清完整版| 久久精品青青大伊人av| 亚洲精品小视频在线观看| 日韩中文在线中文网在线观看| 夜夜嗨av一区二区三区免费区| 91av在线播放| 免费97视频在线精品国自产拍| 精品国产一区二区三区久久久狼| 欧美国产乱视频| 欧美专区日韩视频| 亚洲最大的成人网| 欧美重口另类videos人妖| 日韩电影中文 亚洲精品乱码| 欧美性猛交xxxx免费看漫画| 欧美日韩国产一区二区| 国产亚洲精品美女久久久| 国产精品爽爽ⅴa在线观看| 久久99精品视频一区97| 国产精品三级久久久久久电影| 国产亚洲欧洲高清| 日韩男女性生活视频| 亚洲欧美日韩中文在线制服| 成人黄色在线播放| 精品性高朝久久久久久久| 国产精品久久久精品| 亚洲精品福利免费在线观看| 国产精品久久久久91| 狠狠色狠狠色综合日日五| 美日韩在线视频| 午夜精品在线观看| 国产91在线播放| 国产精品第10页| 日韩成人在线视频观看| 在线观看日韩欧美| 国产香蕉一区二区三区在线视频| 成人www视频在线观看| 欧美另类69精品久久久久9999| 久久久久久久久综合| 亚洲第五色综合网| 久久久午夜视频| 国产精品高潮呻吟久久av黑人| 懂色av一区二区三区| 成人激情在线观看| 欧美成人精品在线播放| 中文字幕欧美日韩va免费视频| 国产欧美日韩精品在线观看| 国产精品视频网站| 亚洲va国产va天堂va久久| 91精品国产综合久久香蕉的用户体验| 午夜精品三级视频福利| 亚洲资源在线看| 国产手机视频精品| 亚洲国产91色在线| 欧美性极品xxxx娇小| 国产视频久久网| 欧美电影第一页| 一夜七次郎国产精品亚洲| 这里只有精品丝袜| 亚州精品天堂中文字幕| 日韩视频在线观看免费| 国产精品久久久一区| 日韩欧美在线视频观看| 亚洲第一中文字幕在线观看| 日韩精品中文字幕在线观看| 亚洲精品影视在线观看| 亚洲free嫩bbb| 日本精品视频在线| 九色精品美女在线| 亚洲精品一区二区网址| 69久久夜色精品国产7777| 国产精品99免视看9| 欧美成人免费一级人片100| 日韩中文在线不卡| 精品中文字幕在线2019| 国产精品丝袜高跟| 俺去亚洲欧洲欧美日韩| 亚洲国产精品va在线观看黑人| 九九视频直播综合网| 国产精品久久久久久一区二区| 丁香五六月婷婷久久激情| 91人人爽人人爽人人精88v| 欧美一级高清免费播放| 一本一本久久a久久精品牛牛影视|