RadarURL

웹 프로그래밍
2008.09.26 22:25

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

Views 5085 Votes 0 Comment 0
?

Shortcut

PrevPrev Article

NextNext Article

Larger Font Smaller Font Up Down Go comment Print
?

Shortcut

PrevPrev Article

NextNext Article

Larger Font Smaller Font Up Down Go comment Print
 

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


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


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


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


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


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


  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
No. Category Subject Author Date Views
Notice [공지] 공부 게시판 입니다. 처누 2003.08.18 928081
2473 연애 폭소클럽 제36회 - 즉석미팅 1 (김제동) file JaeSoo 2003.08.18 18981
2472 연애 폭소클럽 제37회 - 즉석미팅 2 (김제동) file JaeSoo 2003.08.18 17808
2471 연애 폭소클럽 제38회 - 방학특집 연애특강 1 (김제동) 1 file JaeSoo 2003.08.18 16361
2470 연애 폭소클럽 제39회 - 방학특집 연애특강 2 (김제동) file JaeSoo 2003.08.18 17828
2469 연애 폭소클럽 제40회 - 방학특집 연애특강 3 (김제동) file JaeSoo 2003.08.18 16842
2468 웹 프로그래밍 이미지 특정 부분에 링크 만들기 처누 2003.08.24 15624
2467 웹 프로그래밍 게시판에 자신의 FTP 자료 올리기 3 처누 2003.08.25 13135
2466 동식물 고양이 클리닉 - 고양이 기르기 file JaeSoo 2003.10.10 13693
2465 동식물 고양이 클리닉 - 고양이 품종 file JaeSoo 2003.10.10 13427
2464 동식물 고양이 클리닉 - 2개월에서 4개월령 고양이 관리 file JaeSoo 2003.10.11 13428
2463 동식물 고양이 클리닉 - 4개월에서 9개월령 고양이 관리 file JaeSoo 2003.10.11 13132
2462 동식물 고양이 클리닉 - 다자란 고양이 file JaeSoo 2003.10.13 13922
2461 동식물 고양이 클리닉 - 나이든 고양이 file JaeSoo 2003.10.13 13679
2460 동식물 고양이 클리닉 - 고양이의 영양 file JaeSoo 2003.10.13 13429
2459 동식물 고양이 먹이와 주의사항 file JaeSoo 2003.10.13 13902
2458 동식물 아기 고양이의 식사 file JaeSoo 2003.10.13 11821
2457 동식물 고양이 사료 급여량 file JaeSoo 2003.10.13 12880
2456 기타 편지봉투 쓰는 법 file JaeSoo 2003.10.21 16993
2455 웹 프로그래밍 제로보드 로그인 실패시 이유를 메세지로 알려주기 처누 2003.11.04 8458
2454 웹 프로그래밍 최근 게시물 출력시 링크게시물에 스타일시트 적용하기 처누 2003.11.06 7927
Board Pagination Prev 1 2 3 4 5 6 7 8 9 10 ... 124 Next
/ 124


즐겨찾기 (가족)

JAESOO's HOMEPAGE


YOUNGAE's HOMEPAGE


장여은 홈페이지


장여희 홈페이지


장여원 홈페이지


즐겨찾기 (업무)

알리카페 홀릭

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

말레이시아 KL Sentral 한국인 GuestHouse


즐겨찾기 (취미)

어드민아이디

유에코 사랑회

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

JServer.kr

제이서버 메타블로그

재수 티스토리


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

재수 강의 홈페이지


한소리


VTMODE.COM


숭실대 인공지능학과


숭실대 통신연구실


베너