RadarURL

웹 프로그래밍
2008.09.26 22:25

스크롤 따라다니는 위로,아래로 화살표

조회 수 5085 추천 수 0 댓글 0
?

단축키

Prev이전 문서

Next다음 문서

크게 작게 위로 아래로 댓글로 가기 인쇄
?

단축키

Prev이전 문서

Next다음 문서

크게 작게 위로 아래로 댓글로 가기 인쇄
 

막상 뭐라고 이름짓기 힘들군요 ㅋㅋㅋ


이곳에 적용된..왼쪽에 따라다니는 화살표 입니다.


클릭하면 최상위로 또는 최하위로 이동합니다.


아래남은 공간이 많으면 아래로.. 위에 남은공간이 많으면 위로... 알아서 이동하는 똑똑한 넘입니다.


익스에선..휙휙~ 이동하고 파폭에선 스르륵 이동합니다. (익스에선 사이트 환경에 따라 간혹 버벅이길래...)


본인의 사이트가 가벼워서...익스에서도 스르륵~ 이동되길 원하신다면...


  if (!document.selection)
  {
    ...
  }


위과 같은 if 구문을 벗겨내시면 됩니다.


설치는 간단히 아래 이미지태그와 스크립트를 원하는 곳에 넣어주시면 됩니다. (이미지는 


 )


position 이 absolute 이기때문에 태그상에서(html 코드에서) 넣어주신 위치에 바로 나옵니다만..


살짝 위치를 조정하고 싶으시면.. margin-left:-7px; 값을 조절하시면 가로 위치 이동 가능합니다.


세로 위치는 현재는 화면 중앙입니다만~ 상단이나..하단이나..이런대로 옮기시려면 최하단의


 floater.style.top =  (document.body.scrollTop + ((h-13)/2))+"px" ; 에서


-13 부분을 조절하시면 됩니다.



--이하 소스--


<img id="floater" title="위로/아래로" alt="up,down" onclick="autoUpDown();" src="updown_orange.gif" style="cursor:pointer; margin-left:-7px; position:absolute;" />
  <script>
 function back_top()
 {
  var x = document.body.scrollLeft;
  var y = document.body.scrollTop;
  var step = 2;
  
  if (!document.selection)
  {
   while ((x != 0) || (y != 0)) {
     scroll (x, y);
     step += (step * step / 300);
     x -= step;
     y -= step;
     if (x < 0) x = 0;
     if (y < 0) y = 0;
   }
  }
  scroll (0, 0);
 }


 function back_bottom()
 {
  var endx = document.body.scrollWidth;
  var endy = document.body.scrollHeight;
  var x = document.body.scrollLeft;
  var y = document.body.scrollTop;
  var step = 2;


  if (!document.selection)
  {
   while ((x != endx) || (y != endy)) {
     scroll (0, y);
     step += (step * step / 300);
     x += step;
     y += step;
     if (x > endx) x = endx;
     if (y > endy) y = endy;
   }
  }
  scroll (0, endy);
 }


 function autoUpDown() {
  var h = window.innerHeight || self.innerHeight || document.body.clientHeight;
  if (document.body.scrollTop >= document.body.scrollHeight - (document.body.scrollTop + h))
  {
   back_top();
  } else {
   back_bottom();
  } 
 }


 var floater = document.getElementById("floater");
 window.onscroll = function () {
  var h = window.innerHeight || self.innerHeight || document.body.clientHeight;
  var newTop = (document.body.scrollTop + ((h-13)/2));
  if (newTop > floater.parentNode.offsetTop)
  {
   floater.style.top =  newTop+"px" ;
  } else {
   floater.style.top = floater.parentNode.offsetTop+"px" ;
  }


 }
 window.onresize = function () {
  var h = window.innerHeight || self.innerHeight || document.body.clientHeight;
  var newTop = (document.body.scrollTop + ((h-13)/2));
  if (newTop > floater.parentNode.offsetTop)
  {
 


막상 뭐라고 이름짓기 힘들군요 ㅋㅋㅋ


이곳에 적용된..왼쪽에 따라다니는 화살표 입니다.


클릭하면 최상위로 또는 최하위로 이동합니다.


아래남은 공간이 많으면 아래로.. 위에 남은공간이 많으면 위로... 알아서 이동하는 똑똑한 넘입니다.


익스에선..휙휙~ 이동하고 파폭에선 스르륵 이동합니다. (익스에선 사이트 환경에 따라 간혹 버벅이길래...)


본인의 사이트가 가벼워서...익스에서도 스르륵~ 이동되길 원하신다면...


  if (!document.selection)
  {
    ...
  }


위과 같은 if 구문을 벗겨내시면 됩니다.


설치는 간단히 아래 이미지태그와 스크립트를 원하는 곳에 넣어주시면 됩니다. (이미지는 



 )



position 이 absolute 이기때문에 태그상에서(html 코드에서) 넣어주신 위치에 바로 나옵니다만..


살짝 위치를 조정하고 싶으시면.. margin-left:-7px; 값을 조절하시면 가로 위치 이동 가능합니다.


세로 위치는 현재는 화면 중앙입니다만~ 상단이나..하단이나..이런대로 옮기시려면 최하단의


 floater.style.top =  (document.body.scrollTop + ((h-13)/2))+"px" ; 에서


-13 부분을 조절하시면 됩니다.



--이하 소스--


<img id="floater" title="위로/아래로" alt="up,down" onclick="autoUpDown();" src="updown_orange.gif" style="cursor:pointer; margin-left:-7px; position:absolute;" />
  <script>
 function back_top()
 {
  var x = document.body.scrollLeft;
  var y = document.body.scrollTop;
  var step = 2;
  
  if (!document.selection)
  {
   while ((x != 0) || (y != 0)) {
     scroll (x, y);
     step += (step * step / 300);
     x -= step;
     y -= step;
     if (x < 0) x = 0;
     if (y < 0) y = 0;
   }
  }
  scroll (0, 0);
 }


 function back_bottom()
 {
  var endx = document.body.scrollWidth;
  var endy = document.body.scrollHeight;
  var x = document.body.scrollLeft;
  var y = document.body.scrollTop;
  var step = 2;


  if (!document.selection)
  {
   while ((x != endx) || (y != endy)) {
     scroll (0, y);
     step += (step * step / 300);
     x += step;
     y += step;
     if (x > endx) x = endx;
     if (y > endy) y = endy;
   }
  }
  scroll (0, endy);
 }


 function autoUpDown() {
  var h = window.innerHeight || self.innerHeight || document.body.clientHeight;
  if (document.body.scrollTop >= document.body.scrollHeight - (document.body.scrollTop + h))
  {
   back_top();
  } else {
   back_bottom();
  } 
 }


 var floater = document.getElementById("floater");
 window.onscroll = function () {
  var h = window.innerHeight || self.innerHeight || document.body.clientHeight;
  var newTop = (document.body.scrollTop + ((h-13)/2));
  if (newTop > floater.parentNode.offsetTop)
  {
   floater.style.top =  newTop+"px" ;
  } else {
   floater.style.top = floater.parentNode.offsetTop+"px" ;
  }


 }
 window.onresize = function () {
  var h = window.innerHeight || self.innerHeight || document.body.clientHeight;
  var newTop = (document.body.scrollTop + ((h-13)/2));
  if (newTop > floater.parentNode.offsetTop)
  {
   floater.style.top =  newTop+"px" ;
  } else {
   floater.style.top = floater.parentNode.offsetTop+"px" ;
  }
 }
 var h = window.innerHeight || self.innerHeight || document.body.clientHeight;
 floater.style.top =  (document.body.scrollTop + ((h-13)/2))+"px" ;
</script>

출처 : http://www.alik.info/gnu/bbs/board.php?bo_table=alik&wr_id=1344
?

공부 게시판

공부에 도움되는 글을 올려주세요.

List of Articles
번호 분류 제목 글쓴이 날짜 조회 수
공지 [공지] 공부 게시판 입니다. 처누 2003.08.18 928104
346 응용 프로그래밍 WIndows Application의 실행 속도 측정 file JaeSoo 2023.09.06 3185
345 웹 프로그래밍 메모리 부족 현상 (allowed memory size of 134217728 bytes..) JaeSoo 2023.08.01 2207
344 웹 프로그래밍 Guzzle - cURL error 60: SSL certificate problem: unable to get local issuer certificate 문제 해결 file JaeSoo 2023.07.30 2188
343 웹 프로그래밍 XE 캐시파일 재성생후 404 Oops, Sorry. Page is not found! 나올때 JaeSoo 2023.07.29 2117
342 응용 프로그래밍 [Apple] 엔터프라이즈 계정신청 (Enterprise Program) file JaeSoo 2023.03.27 267
341 웹 프로그래밍 XE - " Fatal error: Class 'Object' not found in " / class 낫파운드 오류 file JaeSoo 2023.03.20 147
340 응용 프로그래밍 [MSA] MSA란 무엇인가? 개념 이해하기 file JaeSoo 2023.01.26 210
339 웹 프로그래밍 iOS 앱 개발을 위한 인증서 생성 및 관리 file JaeSoo 2023.01.18 218
338 프로그래밍 [ iOS ] 앱 스토어 개인, 회사, 엔터프라이즈 차이점 file JaeSoo 2023.01.09 237
337 웹 프로그래밍 PHP 파서 이해하기 (<?php의 php를 생략하고 간단히 <? 태그 와 ?> 태그를 사용하는 방법) JaeSoo 2016.08.10 322
336 프로그래밍 SVN의 cleanup 에러시 해결방법 JaeSoo 2016.05.05 728
335 프로그래밍 [오류해결] svn cleanup failed-previous operation has not finished; run cleanup if it was interrupted file JaeSoo 2016.05.05 611
334 프로그래밍 TortoiseSVN 계정변경 file JaeSoo 2016.05.05 582
333 프로그래밍 SVN passwd 설정 : 계정 (users/passwd) file JaeSoo 2016.05.04 543
332 웹 프로그래밍 XE 비회원 글쓰기 항목 지우기 file JaeSoo 2016.04.28 499
331 응용 프로그래밍 메모리 영역 (code, data, stack, heap) file JaeSoo 2016.03.23 747
330 응용 프로그래밍 [SVN] Subversion 명령들 file JaeSoo 2016.02.06 967
329 응용 프로그래밍 IBM JDK 1.6 에서 Spring 2.5.2를 사용할 때 GenericTypeResolver 에서 NullPointerException이 발생하는 문제 JaeSoo 2016.01.27 787
328 웹 프로그래밍 오른쪽 마우스 금지 소스 / 드래그 금지 소스 JaeSoo 2016.01.20 475
327 응용 프로그래밍 [전자정부 표준프레임워크] 톰캣(Tomcat) 설치하기 file JaeSoo 2016.01.02 535
Board Pagination Prev 1 2 3 4 5 6 7 8 9 10 ... 18 Next
/ 18


즐겨찾기 (가족)

JAESOO's HOMEPAGE


YOUNGAE's HOMEPAGE


장여은 홈페이지


장여희 홈페이지


장여원 홈페이지


즐겨찾기 (업무)

알리카페 홀릭

숭실대 컴퓨터 통신연구실 (서창진)

말레이시아 KL Sentral 한국인 GuestHouse


즐겨찾기 (취미)

어드민아이디

유에코 사랑회

아스가르드 좋은사람/나쁜사람

JServer.kr

제이서버 메타블로그

재수 티스토리


즐겨찾기 (강의, 커뮤니티)

재수 강의 홈페이지


한소리


VTMODE.COM


숭실대 인공지능학과


숭실대 통신연구실


베너