• 회원가입
  • 로그인
  • 구글아이디로 로그인

[js] JS - 스크롤 정도/위치 진행바 표시기 (Scroll Indicator Bar)

Scroll Indicator Bar 적용 방법

1. 아래 좌표 코드 참고 (샘플)

 

https://codepen.io/tymoshenkoyelyzaveta/pen/QWyKBJa



2. <body> 태그 바로 아래애 아래 코드 추가

※ G5 basic 테마 경우, /theme/basic/head.sub.php 하단.


<div class="scrolled-indicator">

    <div class="scrolled-indicator-fill">

    </div>

</div>

 


3. CSS 파일 하단에 아래 코드 추가

※ G5 basic 테마 경우, /theme/basic/css/default.css 하단.

 

.scrolled-indicator {

  position: fixed;

  top: 0;

  left: 0;

  width: 100%;

  height: 3px;

  background-color: #333;

  z-index:999;

}


.scrolled-indicator-fill {

  width: 0%;

  height: 100%;

  background-color: #e76f51;

}

 


4. </body> 태그 앞쪽에 아래 JS 코드 추가

※ G5 basic 테마 경우, /theme/basic/tail.php 하단 

 

<script>

const scrolledIndicatorFill = document.querySelector(

  ".scrolled-indicator-fill"

);

const btnScrollToTop = document.querySelector("#btnScrollToTop");


// 스크롤 표시 함수

window.addEventListener("scroll", () => {

  //스크롤 가능 정도

  const scrollable = document.documentElement.scrollHeight - window.innerHeight; // 문서전체높이 - window 높이;

  //스크롤 한 정도를 px단위로 표시

  const scroll = window.scrollY;


  let percentageScrolled = 100;

  // 스크롤 가능 시

  if (scrollable > 0) {

    percentageScrolled = Math.ceil((scroll / scrollable) * 100);

  }


  scrolledIndicatorFill.style.width = `${percentageScrolled}%`;

});

</script>

 

PS. 콘텐츠 열람 집중에 방해되니, 가급적이면 적용하지 마세요.



분류 제목
js JS - list 속성 - INPUT 텍스트 필드에 입력 가능한 datalis(데이터리스트)t에 대한 참조 …
js JS - maxLength 속성 ★ - INPUT 입력 가능 최대 글자수 설정/반환 (= maxLength속…
js JS - name 속성 - INPUT 텍스트 필드의 네임 설정/반환 (= name속성 = 네임속성) ※ 인풋…
js JS - pattern 속성 - INPUT 텍스트 정규식패턴 설정/반환 (= pattern속성 = 패턴속성)…
js JS - placeholder 속성 - INPUT 텍스트 플레이스홀더 설정/반환 (= placeholder속…
js JS - readOnly 속성 - INPUT 텍스트 읽기전용 설정/반환 (= readOnly속성 = 리드온리…
js JS - required 속성 - INPUT 텍스트 필수입력 여부 설정/반환 (= required속성 = 리…
js JS - size 속성 - INPUT 텍스트 size 속성 설정/반환 (= size속성 = 사이즈속성) ※ …
js JS - type 속성 - INPUT 텍스트 타입 반환 (= type속성 = 타입속성)
js JS - value 속성 ★ - INPUT 텍스트 필드의 value 속성값 설정/반환 (= value속성 =…
js JS - 스크롤 시, 로고이미지 변경 (Scroll logo image change)
js JS - 각 숫자번호 클릭 시, 해당 번호 얼럿창(팝업)으로 띄우기
js JS - 특정 클래스 갖는 자식요소의 부모요소에 사용자 지정 클래스 추가
js JS - 이전페이지로 이동 시 기존 스크롤위치로 이동 (JavaScript vs. jQuery 코드 비교)
js JS - 첨부파일 텍스트 내용 읽기(=얻기/가져오기/불러오기/출력) (※ 한글깨짐 방지코드 추가)
js JS - 숫자를 한글로 읽기/변환
js JS - 숫자 천자리 표시 기호 쉼표(콤마) 제거 함수 (= getInt함수 = 겟인트함수)
js JS - 랜덤이미지 (= 랜덤배너)
js JS - 텍스트 첫글자만 글자색 변경 (= 맨앞글자 색상 변경)
js JS - 자바스크립트 성능 향상 위한 코드 작성법 (= JavaScript Performance)
3/4
목록
찾아주셔서 감사합니다. Since 2012