홈으로 홈으로 | 무료회원가입 | 아이디/비번찾기 | 즐겨찾기
추천음악방송메인홈1대1상담음악방송청취
뽕짝아가씨(무료음악채널)
okTrot(무료음악채널)
전통가요(무료음악채널)

온라이브스토어(앱다운로드)

환상의뽕짝파티 무료음악
명작트로트메들리 무료음악
트로트메들리관광 무료음악
동영상노래방
가사검색

POP Player
신나는 고스톱
컴퓨터 오목
작은 음악다방
자동러시 웹플레이어신청

보안∵서버∵쿠키
윈도우∵프레임
이미지∵배경
시간∵달력∵계산
상태바∵타이틀바
음악∵영상
폼∵전송∵테이블
키보드∵마우스
효과∵링크∵메뉴
Script∵php
기타
PHP 강좌
윈도우관련팁
웹관련팁
홈페이지제작팁
기본강좌
레지스트리
윈도우서버
리눅스서버
Android
홈페이지 TOP 버튼 만들기 + 응용
홈페이지홈페이지 13년 전
┏━━━━┳━━━━━━━━━━━━━━━━━━━━━━━━━
┃0001┃홈페이지 TOP 버튼 + 응용
┗━━━━┻━━━━━━━━━━━━━━━━━━━━━━━━━

┏━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
┗ 서문:

TOP 버튼을 구현하는 방법은 상당히 여러 가지가 있습니다만, 그 중에서 가장 많이 쓰이는 방법은 <a href="#">TOP</a> 이라 생각합니다. 여러 가지 이유가 있겠지만, 역시 간단하는 것 때문이겠죠.

일반적인 TOP버튼이라면 <a> 태그를 이용하는 것이 효율적이겠지만, JavaScript를 이용해서 TOP 버튼 구현하게 되면, 여러 가지 효과를 줄 수 있기 때문에, 조금 더 멋진 사이트를 만들 수 있게 됩니다.

아래 소스는 scroll 함수를 이용해서 구현한 TOP 버튼, 그리고 그 응용작들입니다.

┏━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
┗ 소스:

<script type="text/javascript">
<!--
        function to_top() // TOP 버튼을 위한 함수
        {
                scroll (0, 0);   // 스크롤을 0, 0으로 지정합니다.
        }

        function to_bottom()     // 응용: 페이지 가장 아래로 가는 버튼을 위한 함수
        {
               var maxy = document.body.scrollHeight;  // 페이지의 총 상하스크롤 길이를 구합니다
               scroll (0, maxy);    // 스크롤을 0, maxy로 지정합니다.
        }

        function to_top_constant()    // 응용: 일정한 속도 + TOP
        {
               var x = document.body.scrollLeft;   // 페이지의 좌우스크롤 위치를 구합니다.
               var y = document.body.scrollTop;    // 페이지의 상하스크롤 위치를 구합니다.
               var speed = 1;      // 스크롤 속도를 지정합니다. (클수록 빠름)
  
               while ((x != 0) || (y != 0)) {     // 스크롤 위치가 0이 될 때까지 반복합니다
                       scroll (x, y);    // 지정된 x, y 스크롤로 이동합니다.
                       x -= speed;    // 좌우스크롤 위치가 0에 가깝게 되도록 스크롤 속도만큼 빼줍니다.
                       y -= speed;    // 상하스크롤 위치가 0에 가깝게 되도록 스크롤 속도만큼 빼줍니다
                       if (x < 0) x = 0;   // 만약 좌우스크롤 위치가 0보다 작아지면, 0으로 돌려줍니다.
                       if (y < 0) y = 0;   // 만약 상하스크롤 위치가 0보다 작아지면, 0으로 돌려줍니다.
               }
               scroll (0, 0);    // 마지막으로 스크롤을 0, 0으로 이동시킵니다.
        }
  
        function to_bottom_constant()      // 응용: 일정한 속도 + BOTTOM
        {
               var x = document.body.scrollLeft;
               var y = document.body.scrollTop;
               var maxy = document.body.scrollHeight;
               var speed = 1;
  
               while ((x != 0) || (y != maxy)) {   // 좌우스크롤 위치가 0이 될 때까지,
                       scroll (x, y);              // 상하스크롤 위치가 maxy가 될 때까지 반복합니다.
                       x -= speed;
                       y += speed;                 // 상하스크롤 위치를 스크롤 속도만큼 증가시켜 줍니다.
                       if (x < 0) x = 0;
                       if (y > maxy) y = maxy;     // 상하스크롤 위치가 maxy를 넘었을 경우 maxy로 돌려줍니다.
               }
               scroll (0, maxy);                   // 마지막으로 스크롤을 0, maxy로 이동시킵니다.
        }
  
        function to_top_smooth()                   // 응용: 가속도 TOP
        {
                var x = document.body.scrollLeft;
                var y = document.body.scrollTop;
                var speed = 1;
  
                while ((x != 0) || (y != 0)) {
                        scroll (x, y);
                        speed += (speed * speed / 100);    // 스크롤 속도를 점점 빠르게 합니다.
                        x -= speed;
                        y -= speed;
                        if (x < 0) x = 0;
                        if (y < 0) y = 0;
                }
                scroll (0, 0);
        }
  
        function to_top_bounce()          // 응용: 상단에 도착 후 공처럼 튀는 효과
        {
               var x = document.body.scrollLeft;
               var y = document.body.scrollTop;
               var speed = 1;                       // 얼마 정도 튕기게 할 지 정합니다.
               var bounce = 300;

               while ((x != 0) || (y != 0)) {
                       scroll (x, y);
                       if (speed < 5) speed += (speed * speed / 100);    // 스크롤 속도가 너무 빨라지지 않도록.
                       x -= speed;
                       y -= speed;
                       if ((y < 0) && (bounce > 50)){        // 상하스크롤이 0에 도착하면.
                              while ((y != bounce)) {        // 상하스크롤이 bounce 값까지 되도록 반복합니다.
                                      scroll (x, y);
                                      speed -= (speed * speed / 100);  // 중력?에 의해서 속도는 감소하도록 합니다.
                                      x -= speed;
                                      y += speed;
                                      if (x < 0) x = 0;
                                      if (y > bounce) y = bounce;   // y 값이 bounce보다, 커지면 bounce로 돌려줍니다.
                              }
                              scroll (0, bounce);     // 스크롤을 0, bounce로 이동 시킵니다.
                              bounce /= 1.5;          // bounce 높이를 줄여줍니다.
                       }
                       if (x < 0) x = 0;
                       if (y < 0) y = 0;
               }
               scroll (0, 0);
        }
//-->
</script>

<span onclick="to_top();">↑TOP</span>    // TOP 버튼 연결 예제

<span onclick="to_bottom();">↓BOTTOM</span>    // BOTTOM 버튼 연결 예제
┏━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
┗ 적용:

자바스크립트는 <a> 태크를 이용해서 연결해줄 수도 있지만, 이벤트를 이용해서 부르는 것이 더 효율적입니다.
예: <span onclick="to_top();">↑TOP</span>

위와 같이 클릭했을 때 함수를 부르게 되는 것이죠.
<span> 태그 외에도 <font>, <div>, <p>, <img> 등 거의 모든 태크에 적용이 가능합니다.
예: <img src="top.gif" onclick="to_top();"></img>

하지만 <a> 태그가 아니면 하이퍼링크로 처리되지 않기 때문에 마우스포인터가 손으로 변하지 않습니다.
따라서 스타일 속성을 조금 건들여주시면 됩니다.
예: <span onclick="to_top();" style="CURSOR: hand">↑TOP</span>

위와 같이 하시면 TOP위에 올렸을 때에, 마우스포인터가 손으로 변하게 됩니다.
물론 다른 태크에도 적용이 가능합니다.
예: <img src="top.gif" onclick="to_top();" style="cursor:pointer"></img>


┏━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
┗ 알림:

소스에는 총 6개의 함수가 있지만, 아마 실제로 쓰실 것은 1, 2개 정도일 것입니다. 쓰지 않는 함수의 경우는 삭제하고 사용하세요.
추천추천 : 172 추천 목록
번호 제목
3,015
 iframe 높이 100% 맞추기
3,014
 curl 함수를 이용한 HTTP REFERER 변경
3,013
 윈도우10 시스템 파일 및 Dism 검사
3,012
 텍스트 줄바꿈, 글자자르기 CSS
3,011
 jQuery Mobile에서 유용한 코드 10가지.
3,010
 [PHP] dirname()함수와 $_SERVER 관련 상수들
3,009
 [PHP] 파일 크기, 사이즈 불러오는 함수, filesize()
3,008
 [jQuery] jQuery Quick API
3,007
 [ transition ] 링크 hover 색상 변화 속도 조절
3,006
 PHP 5.3.0 에서 사라진 함수들 대체
3,005
 어떤 파일들이 include 나 require 되었는지 확인하는 함수(get_included_files)
3,004
 PHP 날짜 형식 및 계산하기(날짜 더하고 빼기)
3,003
 jQuery Mobile에서 유용한 코드 10가지.
3,002
 값이 배열 안에 존재하는지 확인하는 in_array함수
3,001
 사용자가 웹브라우저에서 뒤로가기를 했을때 감지하는 방법
3,000
 [jQuery]버튼 활성화, 비활성화
2,999
 jQuery show() / hide() / toggle() 사용법
2,998
 jquery 여러가지 이벤트
2,997
 border-radius 속성
2,996
 네이버 오픈API 음성합성 API 사용하는 PHP 샘플코드
2,995
 UTF8 한글 자르기..
2,994
 iconv 에러 발생시 계속 처리하기 옵션
2,993
 [PHP] 현재 페이지의 도메인 , URL 정보 알아내기.
2,992
 [PHP] 막강 기능 배열..
2,991
 [CSS] - Input clear `X ` 버튼 제거 ( IE, Chrome, Firefox )
2,990
 [Mobile] - 모바일웹 Href 태그속성들
2,989
 [JqueryMobile] - 현재화면의 가로세로 사이즈 구하기
2,988
 [JqueryMobile] - 화면의 가로, 세로 사이즈 구하는 방법
2,987
 jquery로 가로 넓이(width), 세로 높이(height) 자동 조절
2,986
 iframe 높이 jquery로 자동조절하기
2,985
 jQuery 오른쪽 영역의 높이를 왼쪽 영역의 높이와 동일하게 하기
2,984
 jquery에서 테이블 짝수, 홀수 번째 TR 배경색 변경하기
2,983
 jquery에서 테이블에 마우스 오버시 해당 행의 배경색상 변경하기
2,982
 jquery 스크립트내 특정값 확인하기 (디버깅)
2,981
 jquery cookie (jquery.cookie.js)
목록
인기절정뽕짝파티
인기트로트모음
지루박디스코메들리
밤무대애창곡
전자올겐경음악
세월따라노래따라
가슴시린트로트
트로트쌍쌍파티
7080추억속으로
종합성인가요방
못잊을옛날노래
카바레 음악
트롯디스코팡팡
관광 메들리
트롯카페
가요감상실
추억의옛노래
스페셜가요광장
BillBoard Free
추천가요모음
경음악.전자올겐
스페셜음악여행
WOLRD POPs
K-POP\BillBoard
JP\CN
POP TOP BEST
K.R.노래방

추천가요\인기
F뮤직 인기\발라드
F뮤직 애창\트로트
트로트성인가요
인기가요
프리미엄 POP
경음악\기타
프리미엄 최신가요
프리미엄 성인가요
가요축제\트롯1번지
댄스\메들리\리믹스
카페\명상\경음악\기타
뮤직트로트 부산광역시부산진구 가야동 ㅣ 개인정보취급방침
Copyright (C) musictrot All rights reserved.