웹 프론트엔드 JS 튜토리얼 js에서 스크롤 막대를 사용자 정의하는 방법(코드 첨부)

js에서 스크롤 막대를 사용자 정의하는 방법(코드 첨부)

Aug 28, 2018 pm 04:58 PM
js

이 기사의 내용은 js에서 스크롤 막대를 사용자 정의하는 방법(코드 포함)입니다. 특정 참조 값이 있으므로 도움이 필요한 친구에게 도움이 되기를 바랍니다.

마우스 휠 이벤트

FireFox: DOMMouseScroll

e.detail 3까지 아래로 스크롤 -3

Non-FireFox까지 스크롤: onmousewheel

e.wheelDelta -120까지 아래로 스크롤 120까지 스크롤

사용자 정의 스크롤 막대 소스 코드

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

23

24

25

26

27

28

29

30

31

32

33

34

35

36

37

38

39

40

41

42

43

44

45

46

47

48

49

50

51

52

53

54

55

56

57

58

59

60

61

62

63

64

65

66

67

68

69

70

71

72

73

74

75

76

77

78

79

80

81

82

83

84

85

86

87

88

89

90

91

92

93

94

95

96

97

98

99

100

101

102

103

<!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;       

            }

 

        .ball {

                        width: 100%;           

                        height: 500px;       

                }

 

        #scroll {

                            width: 6px;           

                            height: 96%;           

                            position: fixed;           

                            top: 2%;           

                            right: 5px;          

                            border-radius: 3px;           

                            background-color: rgba(235, 233, 233, 0.5);           

                            z-index: 9998;           

                            opacity: 1;      

                  }

 

        #scrollBar {

                              position: absolute;           

                              z-index: 9999;           

                              width: 6px;           

                              height: 20px;           

                              border-radius: 3px;           

                              left: 0;           

                              top: 0;           

                              background-color: #383838;       

                     }

    </style>

   </head>

   <body style="overflow:hidden;">

    <div id="box">

        <div id="content">

            <p class="ball" style="background-color:lightpink;"></p>

            <p class="ball" style="background-color:blue;"></p>

            <p class="ball" style="background-color:yellow;"></p>

            <p class="ball" style="background-color:lightpink;"></p>

            <p class="ball" style="background-color:blue;"></p>

            <p class="ball" style="background-color:yellow;"></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 data = 30;   

   //  浏览器的可视高度减/页面的总高度*滚动栏的总高度=滚动按钮的高度

    var _eight;

    window.onresize = function (){

        init();

    }   

   function init (){

        _height = window.innerHeight * scroll.offsetHeight / content.offsetHeight;

        scrollBar.style.height = _height + "px";

    }

    init();    //火狐

    box.addEventListener("DOMMouseScroll", function (e) {

        var e = e || event;        if (e.detail > 0) {//向下滚动

            box.scrollTop += data;

        } else {//向上滚动

            box.scrollTop -= data;

        }       

   //浏览器的滚动距离/(页面的总高度-浏览器的可视高度)* (滚动栏的总高度-滚动按钮的高度)= 滚动的距离

        var _top = box.scrollTop * (scroll.offsetHeight - scrollBar.offsetHeight) / (content.offsetHeight - window.innerHeight);

        scrollBar.style.top = _top + "px";

    });    //非火狐

    box.addEventListener("mousewheel", function (e) {

        var e = e || event;       

   if (e.wheelDelta > 0) {//向上滚动

            box.scrollTop -= data;

        } else {//向下滚动

            box.scrollTop += data;

        }       

   //浏览器的滚动距离/(页面的总高度-浏览器的可视高度)* (滚动栏的总高度-滚动按钮的高度)= 滚动的距离

        var _top = box.scrollTop * (scroll.offsetHeight - scrollBar.offsetHeight) / (content.offsetHeight - window.innerHeight);

        scrollBar.style.top = _top + "px";

    });

   </script>

로그인 후 복사

관련 권장 사항:

JS 구현된 페이지 사용자 정의 스크롤 막대 효과_javascript 기술

네이티브 js의 코드 사례 공유 사용자 정의 스크롤 막대의 캡슐화

위 내용은 js에서 스크롤 막대를 사용자 정의하는 방법(코드 첨부)의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.

뜨거운 기사 태그

메모장++7.3.1

메모장++7.3.1

사용하기 쉬운 무료 코드 편집기

SublimeText3 중국어 버전

SublimeText3 중국어 버전

중국어 버전, 사용하기 매우 쉽습니다.

스튜디오 13.0.1 보내기

스튜디오 13.0.1 보내기

강력한 PHP 통합 개발 환경

드림위버 CS6

드림위버 CS6

시각적 웹 개발 도구

SublimeText3 Mac 버전

SublimeText3 Mac 버전

신 수준의 코드 편집 소프트웨어(SublimeText3)

JS 및 Baidu Maps를 사용하여 지도 이동 기능을 구현하는 방법 JS 및 Baidu Maps를 사용하여 지도 이동 기능을 구현하는 방법 Nov 21, 2023 am 10:00 AM

JS 및 Baidu Maps를 사용하여 지도 이동 기능을 구현하는 방법

주식 분석을 위한 필수 도구: PHP 및 JS를 사용하여 캔들 차트를 그리는 단계를 알아보세요. 주식 분석을 위한 필수 도구: PHP 및 JS를 사용하여 캔들 차트를 그리는 단계를 알아보세요. Dec 17, 2023 pm 06:55 PM

주식 분석을 위한 필수 도구: PHP 및 JS를 사용하여 캔들 차트를 그리는 단계를 알아보세요.

권장 사항: 우수한 JS 오픈 소스 얼굴 감지 및 인식 프로젝트 권장 사항: 우수한 JS 오픈 소스 얼굴 감지 및 인식 프로젝트 Apr 03, 2024 am 11:55 AM

권장 사항: 우수한 JS 오픈 소스 얼굴 감지 및 인식 프로젝트

PHP 및 JS 개발 팁: 주식 캔들 차트 그리기 방법 익히기 PHP 및 JS 개발 팁: 주식 캔들 차트 그리기 방법 익히기 Dec 18, 2023 pm 03:39 PM

PHP 및 JS 개발 팁: 주식 캔들 차트 그리기 방법 익히기

PHP와 JS를 사용하여 주식 촛대 차트를 만드는 방법 PHP와 JS를 사용하여 주식 촛대 차트를 만드는 방법 Dec 17, 2023 am 08:08 AM

PHP와 JS를 사용하여 주식 촛대 차트를 만드는 방법

JS 및 Baidu Maps를 사용하여 지도 다각형 그리기 기능을 구현하는 방법 JS 및 Baidu Maps를 사용하여 지도 다각형 그리기 기능을 구현하는 방법 Nov 21, 2023 am 10:53 AM

JS 및 Baidu Maps를 사용하여 지도 다각형 그리기 기능을 구현하는 방법

JS와 Baidu Map을 활용하여 지도 클릭 이벤트 처리 기능을 구현하는 방법 JS와 Baidu Map을 활용하여 지도 클릭 이벤트 처리 기능을 구현하는 방법 Nov 21, 2023 am 11:11 AM

JS와 Baidu Map을 활용하여 지도 클릭 이벤트 처리 기능을 구현하는 방법

JS 및 Baidu Maps를 사용하여 지도 히트맵 기능을 구현하는 방법 JS 및 Baidu Maps를 사용하여 지도 히트맵 기능을 구현하는 방법 Nov 21, 2023 am 09:33 AM

JS 및 Baidu Maps를 사용하여 지도 히트맵 기능을 구현하는 방법

See all articles