[JS] gif 이미지를 이용한 투명 로딩바, 로딩서클 만들기 [loading bar, loading circle 만들기, 스크롤 고정하는 방법]

2023. 9. 26. 20:58·◎ JavaScript/JavaScript🦎
728x90


- gif 이미지를 이용한 로딩바, 로딩서클 만들기

데이터를 처리할 때 화면에 표시되는 로딩바, 로딩서클을 만들어보려 한다. 두 개의 함수만 구현하면 되기에 꽤나 간단하다. (아래 코드는 jQuery로 구현해놓았기에 cdnjs에서 jQuery를 받아와야 한다.)

 

[jQuery] 제이쿼리(jQuery)란? [cdnjs에서 HTML로 jQuery 불러오기]

1. 제이쿼리(jQuery)란? HTML에 애니메이션, 이벤트 처리 등 다양한 기능을 부여해 주는 라이브러리 2. 제이쿼리(jQuery) 적용 방법 - jQuery 소스 : cdnjs jquery - Libraries - cdnjs - The #1 free and open source CDN built

yermi.tistory.com

 

[꿀팁] 투명 로딩바, 로딩서클 이미지 무료 사이트 [GIFER, 투명 배경 gif 사이트]

- 로딩바, 로딩서클 이미지 무료 사이트 배경이 투명인 gif가 필요할 때 유용하게 쓸 수 있는 사이트, GIFER를 추천한다. "loading" GIFs - the best GIFs on GIFER Found on GIFER - the largest GIF search engine on the Intern

yermi.tistory.com


- 로딩 이미지 생성 / createLoadingImage()

function createLoadingImage() {
    document.body.style.overflow = 'hidden'; // 스크롤 고정

    // 로딩 이미지에 대한 스타일 지정
    const backGroundStyle = `position: absolute; z-index: 2000; background-color: #000000; display:none; left:0; top:0;`;
    const loadingStyle = `position:absolute; left:45%; top:2%; display:none; z-index:3000;`;

    // 배경 div
    let backGroundCover = "<div id='back' style='" + backGroundStyle + "'></div>";
    
    // 로딩 이미지 div
    let loadingImage = '';
    loadingImage += "<div id='loadingBar' style='" + loadingStyle + "'>";
    loadingImage += "     <img style='width:30%;' src='로딩 이미지 경로'/>";
    loadingImage += "</div>";
 
    // body에 추가
    $('body').append(backGroundCover).append(loadingImage); 
    
    // css 적용 및 보이기
    $('#back').css({ 'width': window.document.body.clientWidth, 'height': $(document).height(), 'opacity': '0.3' });
    $('#back').show();
    $('#loadingBar').show();
}

- 로딩 이미지 제거 / removeLoadingImage()

function removeLoadingImage() {
    document.body.style.overflow = 'auto'; // 스크롤 고정 해제
    
    // 배경, 로딩 이미지 제거
    $('#back, #loadingBar').hide();
    $('#back, #loadingBar').remove();
}

 

이 두 함수를 아래와 같이 로직의 시작과 끝에 배치를 하면 로딩 이미지가 생성된다.
function test() {
    createLoadingImage(); // 로딩 이미지 생성
    /* 데이터 처리 로직 구현 */
    removeLoadingImage(); // 로딩 이미지 제거
}

 


 

로딩서클 구현 완료


- 참고자료

 

[Javascript] 로딩바 만들기

안녕하세요~! 오늘의 포스팅에서는 간단한 로딩바를 만들어 주는 방법을 알아보겠습니다. 웹 사이트나 모바일 화면에서 무언가 데이터 처리를 할 때 화면 중앙에 빙글빙글 돌아가는걸 다들 본

newehblog.tistory.com


728x90
'◎ JavaScript/JavaScript🦎' 카테고리의 다른 글
  • [JS] 자바스크립트에서 두 날짜 사이 비교하기 [두 날짜 사이의 일수, 월, 연도 구하기]
  • [JS] 자바스크립트에서 NaN 값 비교하는 방법 [NaN이란? Not-A-Number(숫자가 아님)]
  • [JS] 현재 페이지 URL과 파라미터 가져오기 [URLSearchParams 객체 사용하여 parameter를 js 변수에 담기]
  • [JS] 자바스크립트에 Excel 데이터 가져오기 [SheetJS, 엑셀 파일 다루는 라이브러리]
예르미(yermi)
예르미(yermi)
끊임없이 제 자신을 계발하는 개발자입니다👨🏻‍💻
  • 예르미(yermi)
    예르미의 코딩노트
    예르미(yermi)
  • 전체
    오늘
    어제
    • 분류 전체보기 (937)
      • ◎ Java (133)
        • Java☕ (93)
        • JSP📋 (26)
        • Applet🧳 (6)
        • Interview👨🏻‍🏫 (8)
      • ◎ JavaScript (48)
        • JavaScript🦎 (25)
        • jQuery🌊 (8)
        • React🌐 (2)
        • Vue.js🔰 (6)
        • Node.js🫒 (3)
        • Google App Script🐑 (4)
      • ◎ HTML5+CSS3 (17)
        • HTML5📝 (8)
        • CSS3🎨 (9)
      • ──────────── (0)
      • ▣ Framework (67)
        • Spring🍃 (36)
        • Spring Boot🍀 (12)
        • Bootstrap💜 (3)
        • Selenium🌕 (6)
        • MyBatis🐣 (10)
      • ▣ Tools (47)
        • API🎯 (18)
        • Library🎲 (15)
        • JitPack🚀 (3)
        • Jenkins👨🏻 (7)
        • Thymeleaf🌿 (4)
      • ▣ Server (32)
        • Apache Tomcat🐱 (14)
        • Apache HTTP Server🛡️ (1)
        • Nginx🧶 (7)
        • OracleXE💿 (4)
        • VisualSVN📡 (4)
      • ▣ OS : 운영체제 (18)
        • cmd : 명령프롬프트💻 (10)
        • Linux🐧 (8)
      • ▣ SQL : Database (56)
        • Oracle SQL🏮 (26)
        • PL SQL💾 (9)
        • MySQL🐬 (6)
        • MariaDB🦦 (6)
        • H2 Database🔠 (3)
        • SQL 실전문제🐌 (6)
      • ────────── (0)
      • ◈ Human Project (86)
        • Mini : Library Service📚 (15)
        • 화면 설계 [HTML]🐯 (10)
        • 서버 프로그램 구현🦁 (15)
        • Team : 여수어때🛫 (19)
        • Custom : Student🏫 (9)
        • Custom : Board📖 (18)
      • ◈ Yermi Project (40)
        • 조사모아(Josa-moa)📬 (5)
        • Riddle-Game🧩 (6)
        • 맛있을 지도🍚 (2)
        • 어디 가! 박대리!🙋🏻‍♂️ (5)
        • 조크베어🐻‍❄️ (4)
        • Looks Like Thirty🦉 (2)
        • Toy Project💎 (12)
        • 오픈소스 파헤치기🪐 (4)
      • ◈ Refactoring (15)
        • Mini : Library Service📚 (8)
        • 서버 프로그램 구현🦁 (1)
        • Team : 여수어때🛫 (0)
        • 쿼리 튜닝일지🔧 (6)
      • ◈ Coding Test (89)
        • 백준(BOJ)👨🏻‍💻 (70)
        • 프로그래머스😎 (2)
        • 코드트리🌳 (7)
        • 알고리즘(Algorithm)🎡 (10)
      • ◈ Study (102)
        • 기초튼튼 개발지식🥔 (25)
        • HTTP 웹 지식💡 (4)
        • 클린코드(Clean Code)🩺 (1)
        • 디자인패턴(GoF)🥞 (12)
        • 다이어그램(Diagram)📈 (4)
        • 파이썬(Python)🐍 (16)
        • 에러노트(Error Note)🧱 (34)
        • 웹 보안(Web Security)🔐 (6)
      • ◈ 공부모임 (39)
        • 혼공학습단⏰ (18)
        • 코드트리 챌린지👊🏻 (2)
        • 개발도서 100독👟 (8)
        • 나는 리뷰어다🌾 (11)
      • ◈ 자격증 공부 (37)
        • 정보처리기사🔱 (16)
        • 정보처리산업기사🔅 (9)
        • 컴퓨터활용능력 1급📼 (12)
      • ─────────── (0)
      • ◐ 기타 (113)
        • 알아두면 좋은 팁(tip)✨ (46)
        • 개발자의 일상🎈 (44)
        • 개발도서 서평🔍 (10)
        • 개발관련 세미나🎤 (2)
        • 블로그 꾸미기🎀 (9)
        • 사도신경 프로젝트🎚️ (2)
  • 인기 글

  • 최근 댓글

  • 태그

    코딩 테스트
    jsp
    백준
    백준 티어
    BOJ
    Oracle
    꿀팁
    CSS
    일상
    Database
    Error Note
    프로그래밍
    Java
    자바스크립트
    html
    javascript
    코딩
    spring
    SQL
    Project
  • 250x250
  • hELLO· Designed By정상우.v4.10.3
예르미(yermi)
[JS] gif 이미지를 이용한 투명 로딩바, 로딩서클 만들기 [loading bar, loading circle 만들기, 스크롤 고정하는 방법]
상단으로

티스토리툴바