테스트 사이트 - 개발 중인 베타 버전입니다

갤러리 게시판 내 첨부 파일을 분리하여 출력하기

· 1년 전 · 1138 · 7

질문 게시판 내 

 

https://sir.kr/qa/542681

 

첨부 파일이 여러개 일 때 맨 처음만 보이고

 

그 이외에는 하단에 작은 썸네일로 출력한 다음 클릭 시 상단의 이미지가 변경되는 방법입니다.

 

아래 움짤 확인하세요

 

 

 

사용하시는 게시판 스킨 / view.skin 파일을 열어 아래 코드를 찾아주세요

 

[code]

<?php

        // 파일 출력

        $v_img_count = count($view['file']);

        if($v_img_count) {

            echo "<div id=\"bo_v_img\">\n";

 

            foreach($view['file'] as $view_file) {

                echo get_file_thumbnail($view_file);

            }

 

            echo "</div>\n";

        }

         ?>

[/code]

 

이 코드를 아래 처럼 수정(그냥 변경하세요 싹)해주세요

[code]

<?php

    echo "<div id='main-image' style='width: 500px; height: 500px;'>";

    // 첫 번째 이미지 크게 출력

    $v_img_count = count($view['file']);

    if($v_img_count) {

        echo get_view_thumbnail($view['file'][0]['view'], 500);

    }

    echo "</div>";

     

    // 추가 이미지 원본 출력

    if ($v_img_count > 1) {

        echo "<div id='thumbnail-container' style='display: flex; gap: 10px; margin-top: 10px;'>";

        for ($i = 0; $i < min($v_img_count - 1, 6); $i++) {  // 최대 5개의 원본 이미지 표시

            echo "<div class='thumbnail' style='width: 100px; height: 100px; overflow: hidden;'>";

            // 썸네일 생성을 위해 get_file_thumbnail 함수 사용

            $thumb = $view['file'][$i]['view'];

            preg_match('/src="([^"]+)"/', $thumb, $matches);

            $image_url = isset($matches[1]) ? $matches[1] : '';

            // 이미지 주소만 추출

            if ($image_url) {

                echo "<img src='" . $image_url . "' data-full='" . $image_url . "' style='width: 100%; height: 100%; object-fit: cover; cursor: pointer;' />";

            }

            echo "</div>\n";

        }

        echo "</div>\n";

    }

?>

<script>

    document.querySelectorAll('#thumbnail-container .thumbnail img').forEach(function(thumb) {

        thumb.addEventListener('click', function() {

            // 메인 이미지를 클릭된 썸네일의 큰 이미지로 변경

            document.getElementById('main-image').innerHTML = "<img src='" + this.getAttribute('data-full') + "' style='width: 100%; height: 100%; object-fit: cover;' />";

        });

    });

</script>

[/code]

 

고맙습니다.

댓글 작성

댓글을 작성하시려면 로그인이 필요합니다.

로그인하기

댓글 7개

1년 전

좋은 자료 감사합니다.^^

1년 전

감사 합니다. 에디터 이미지도 되네요..

감사합니다

감사합니다

1년 전

감사합니다

11개월 전

감사합니다.

7개월 전

중앙으로 정렬 시키려면 어떻게 해야 할 까요?

align-items: center; 넣어 줘도 움직이지 않아서요.

게시글 목록

번호 제목
22569
22566
22565
22559
22530
22527
22525
22521
22518
22506
22500
22490
22487
22481
22480
22473
22471
22468
22453
22449
22440
22436
22435
22415
22407
22404
22376
22364
22362
22353