[JavaScript] 이미지 원본 크기로 보기

페이지 정보

shadow2fox 1,599 2 2 2021.03.14 23:49

평점

  • 평점 : 5점 (2명 참여)

본문

📝 이미지 원본 크기로 보기
자바스크립트와 jQuery를 사용할 수 있는 환경이라면 아래 소스의 선택 엘리먼트와 팝업 함수의 제목만 입맛에 맞도록 바꾸어 적용하면 된다.

$(document).ready(function() {
    $('img').load(function(){
        var img = $(this);
        var width = img[0].naturalWidth;
        console.log(width);
        var winwidth = $(".board-view-atc").width();
        console.log(winwidth);
        if(width > winwidth){
            if(!(img[0].closest('a'))) {
                img.addClass('zoomable');
                $('img.zoomable').css('cursor', 'zoom-in');
            }
        }
  })
});

function image_popup(url) {
    var imgObj = new Image();
    imgObj.src = url;
    var left = (screen.width - imgObj.width)/2;
    imageWin = window.open("", "profile_popup", "width=" + imgObj.width + "px, height=" + imgObj.height + "px, left=" + left +"px");
    imageWin.document.write("<html><body style='margin:0'>");
    imageWin.document.write("<a href=javascript:window.close()><img src='" + imgObj.src + "' style='max-width:100%;cursor:zoom-out'></a>");
    imageWin.document.write("</body><html>");
    imageWin.document.title = "{=cut_str(get_text(view.wr_subject), 120)}";
}

$('body').on('click','img.zoomable',function(){
    var img = $(this);
    var src = img.attr('src');
    image_popup(src);
});
$('img').load(function()은 이미지가 로딩될 때마다 이미지의 넓이를 검증하고 board-view-atc 클래스보다 크면 zoomable 클래스를 이미지에 추가하고 zoom-in 커서 스타일을 추가한다.

$('body').on('click','img.zoomable',function()은 zoomable 클래스를 지닌 img를 클릭할 때 image_popup함수를 호출한다.

function image_popup(url)는 호출된 이미지의 크기를 구하여 사용자 해상도 넓이의 중앙에 맞게 띄우고 팝업 내 이미지에 zoom-out 커서 스타일을 추가하며 이미지를 클릭하면 팝업창을 닫는다.
탬플릿언더바를 이용하는 이윰빌더일 경우 게시글 제목을 잘라서 팝업 제목으로 사용한다.
추천인 2
  • 내사랑
  • 하늘구장
10
shadow2fox - 회원등급 : 자연/Level 142 - 포인트 : 2,544,196
레벨 142
경험치 3,042,400

Progress Bar 92%

- 가입일 : 2015-03-10 12:21:44
- 서명 : 인간에게 가장 큰 선물은 자기 자신에게 기회를 주는 것이다. - 크리스 가드너, Chris Gardner -
- 자기소개 : There's never a shortcut to happiness.

댓글2

내사랑님의 댓글

내사랑 2021.03.15 15:19
올려 주셨군용 퇴근 후에 적용해야겠네요 아주 많이 감사드립니다

하늘구장님의 댓글

하늘구장 2021.03.15 00:03
그누보드에서 제공된 이미지 팝업 기능을 사용치 않는 경우 아주 유용한 팁이네요 정말 감사합니다

축하합니다. 첫 댓글로 1경험치를 획득하였습니다.

축하합니다. 행운의 73경험치를 획득하였습니다.

Total 1311 페이지
제목 글쓴이 날짜 조회 추천
JavaScript  댓글+2🏆 Prism.js 플러그인 Copy to Clipboard Button 이용 시 빈칸이 추가되는 문제 해결하기 shadow2fox 2021.06.22 1,145 2
JavaScript  댓글+1 텍스트 타입의 input 태그에 텍스트 입력 시 앞뒤 공백제거 shadow2fox 2021.06.20 891 1
JavaScript  댓글+2🏆 🚩 이미지 원본 크기로 보기 shadow2fox 2021.03.14 1,600 2
JavaScript  🏆 오프스크린 이미지(Offscreen Images) 지연하기 shadow2fox 2018.12.27 3,376 2
JavaScript  🏆 현재창 아이프레임 유무 확인 shadow2fox 2018.12.26 1,702 0
JavaScript  🏆 사용자의 브라우저를 검출하는 방법 shadow2fox 2018.08.22 1,819 0
JavaScript  🏆 반응형 테마에서 Theia Sticky Sidebar 사용시 레이아웃이 중첩되는 문제 해결하기 루루아빠 2017.04.22 2,422 0
JavaScript  🏆 gifplayer를 통해 동영상 재생시 오디오 문제 루루아빠 2016.08.06 2,628 0
JavaScript  🏆 모달창(Modal Window) backdrop(모달창 바깥 부분) 클릭시 모달창 닫지 않기 루루아빠 2016.05.06 3,410 0
JavaScript  🏆 특정 div의 내용을 일정 시간마다 새로고침하기 루루아빠 2016.03.20 14,831 1
JavaScript  🏆 마우스 오른쪽 버튼 사용시 경고 메세지 띄우기 루루아빠 2015.10.31 2,546 0
JavaScript  🏆 아이프레임 자동으로 갱신하기 루루아빠 2015.06.05 3,181 0
JavaScript  댓글+3🏆 단축키로 페이지 이동 루루아빠 2015.05.28 4,068 0