메뉴 건너뛰기

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

단축키

Prev이전 문서

Next다음 문서

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

단축키

Prev이전 문서

Next다음 문서

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

* 일반적으로는 a href="#아이디"등과 같이 사용자가 클릭을 해야하는 경우가 있는데, 이러한 경우가 아닌, 자바스크립트로 이동하는 방법을 알아보자. 이러한 경우는 페이지의 bookmark를 등록하거나 할 때 해당 위치로 이동하도록 할 때에 편리할 것이다.


: 먼저 html에 id를 준다.


<div id="bookmark"></div>


: 그리고 해당 element로 이동하고 싶을 때 아래와 같은 자바스크립트를 호출하면 된다.


location.href = "#";
location.href = "#bookmark";

: 이 방법은 아주 쉽게 <a href="#bookmark"> 의 링크/버튼을 누르지 않고 그와 같은 효과를 이끌어낼 수 있다. 하지만 url의 뒤에 #bookmark가 추가되는 불편함(?)이 있을지도 모른다. 사실, url이 그렇게 변하는 것은 미관상(?) 안 좋을수도 있지만, 백스페이스를 누르면 원래의 위치로 가는 것과 즐겨찾기를 하게 되면 해당 위치로 바로 이동이 되는 것이 어떻게 보면 페이지에 따라서는 오히려 UX를 증가시킬 수 있는 면도 있다는 것을 알아두자.


: 만약 이러한 UX적인 이점보다 주소의 미관상(?) 이득이 중요하다면 해당 element의 offset top을 구해서 해당 위치로 이동하는 방법을 사용하면 된다.


function getOffsetTop(el) {
  var top = 0;
  if (el.offsetParent) {
    do {
      top += el.offsetTop;
    } while (el = el.offsetParent);
    return [top];
  }
}
window.scroll(0, getOffsetTop(document.getElementById("bookmark")));


: 스크롤 애니메이션을 넣고 싶은 경우에도 이것을 조금 응용하면 될 것이다. jquery의 스크롤 애니메이션도 결국 이러한 소스가 밑바탕에서 돌아가고 있는 셈이기도 하다.


List of Articles
번호 제목 날짜 조회 수
67 이미지클릭시 옆에 큰이미지나오기 2014.03.17 5518
66 따라다니는 배너 2014.03.17 6270
65 입력된 글씨수 제어 file 2014.03.01 6700
64 select 당일 날짜 출력 file 2014.03.01 5780
63 입력된 폼의 내용 똑같이 복사 file 2014.03.01 6892
62 해상도에 따라 배경 바꾸기 2014.03.01 6083
61 input 빈칸 체크 2014.03.01 6271
60 선택된 select 의 option 값을 다른 select로 넘겨주기 2014.03.01 5668
59 checkbox 한개 클릭으로 다른모든 checkbox 클릭되게 하기 2014.03.01 5709
58 자바 스크립트 confirm()함수에서 (확인,취소) -> (예,아니오) file 2014.03.01 10214
57 제목에 한글 영문 숫자 와 공란만 입력하게 하고 싶습니다. 2014.03.01 6461
56 input type checkbox 체크했는지 검사하는 소스 2014.03.01 5469
55 check_inputbox.js 2014.03.01 5407
54 Textarea 글자수 체크 2014.03.01 5651
53 라디오 버튼 체크 2014.03.01 5451
52 iframe 높이 자동으로 잡아주기 2014.03.01 5855
51 영문, 숫자, 한글, 이메일 체크 하는 함수 2014.03.01 5292
50 iframe을 리로드 하자! 2014.03.01 5933
49 이미지나 태그정렬이 안맞을때 absmiddle 2014.03.01 5238
48 form 값 iframe 으로 넘기기 2014.03.01 6872
Board Pagination Prev 1 ... 4 5 6 7 8 9 10 11 12 13 Next
/ 13

하단 정보를 입력할 수 있습니다

© k2s0o1d4e0s2i1g5n. All Rights Reserved