js滾輪事件 js自定義滾動(dòng)條的實(shí)現(xiàn)
本文實(shí)例為大家分享了js自定義滾動(dòng)條的實(shí)現(xiàn)的具體代碼,供大家參考,具體內(nèi)容如下
描述:
自定義滾動(dòng)條的實(shí)現(xiàn)
效果:
實(shí)現(xiàn):
<!DOCTYPE html> <html lang=""> <head> <meta charset="utf-8"> <title></title> <style> * {margin: 0;padding: 0;} html,body { width: 100%;height: 100%;} #box { width: 100%; height: 100%; overflow: hidden;} /*一個(gè)個(gè)劃過去的頁面塊*/ .ball { width: 100%; height: 500px; font-size:100px; font-weight:bold; color: skyblue; text-align: center; line-height:500px; } /*//滾動(dòng)欄*/ #scroll { width: 20px; height: 96%; position: fixed; top: 2%; right: 5px; border-radius: 10px; background-color: rgba(235, 233, 233, 0.5); z-index: 9998; opacity: 0; } /*//滾動(dòng)欄上的小長條*/ #scrollBar { position: absolute; z-index: 1;/*//定在上面*/ width: 20px; height: 40px; border-radius: 10px; left: 0; top: 0; background-color: red;opacity: 0.6; } </style> </head> <body style="overflow:hidden;"> <div id="box"> <div id="content"> <!--//營造div色塊交替的感覺--> <p class="ball" style="background-color:#656565;">1</p> <p class="ball" style="background-color:#ffffff;">2</p> <p class="ball" style="background-color:#656565;">3</p> <p class="ball" style="background-color:#ffffff;">4</p> <p class="ball" style="background-color:#656565;">5</p> <p class="ball" style="background-color:#ffffff;">6</p> </div> </div> <div id="scroll"> <div id="scrollBar"></div> </div> </body> </html> <script type="text/javascript"> var content = document.getElementById("content"); var box = document.getElementById("box"); var scroll = document.getElementById("scroll"); var scrollBar = document.getElementById("scrollBar"); var Step = { value : 0, size : 20, maxVal : Math.ceil((content.offsetHeight-document.body.offsetHeight)/20), getCurrentVal:function(){ return this.value; }, next:function(){ if(this.value==this.maxVal) return; this.value++; }, pre:function(){ if(this.value==0) return; this.value--; }, getDistance:function(){ return this.getCurrentVal()*this.size; }, update:function(){ this.maxVal = Math.ceil((content.offsetHeight-document.body.offsetHeight)/this.size); } } window.addEventListener("resize",function(){ Step.update(); }); box.addEventListener("DOMMouseScroll",scrollfunc); box.addEventListener("mousewheel", scrollfunc); function scrollfunc(e){ if(e.type=="mousewheel"){ //非FF e.wheelDelta<0?Step.next():Step.pre(); } else { //FF e.detail>0?Step.next():Step.pre(); } document.title = Step.getCurrentVal(); box.scrollTop = Math.min(Step.getDistance(),content.offsetHeight-document.body.offsetHeight); //計(jì)算滾動(dòng)比例 var percent = box.scrollTop/(content.offsetHeight-document.body.offsetHeight); //顯示滾動(dòng)條 scroll.style.opacity = 100; //計(jì)算滾動(dòng)條的位置 scrollBar.style.top = (scroll.offsetHeight-scrollBar.offsetHeight)*percent + "px"; } </script>
以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
JS面向?qū)ο缶幊袒A(chǔ)篇(二) 封裝操作實(shí)例詳解
這篇文章主要介紹了JS面向?qū)ο缶幊谭庋b操作,結(jié)合實(shí)例形式詳細(xì)分析了JS面向?qū)ο蠓庋b操作的相關(guān)概念、原理、使用方法與操作注意事項(xiàng),需要的朋友可以參考下2020-03-03

js實(shí)現(xiàn)TAB切換對應(yīng)不同顏色的代碼

原生JS實(shí)現(xiàn)列表子元素順序反轉(zhuǎn)的方法分析

js實(shí)現(xiàn)同一頁面多個(gè)運(yùn)動(dòng)效果的方法

JS使用Promise時(shí)常見的5個(gè)錯(cuò)誤總結(jié)

JavaScript創(chuàng)建對象的幾種方式及關(guān)于this指向問題