PGR21.com
- PGR21 관련된 질문 및 건의는 [건의 게시판]을 이용바랍니다.
- (2013년 3월 이전) 오래된 질문글은 [이전 질문 게시판]에 있습니다.
통합 규정을 준수해 주십시오. (2015.12.25.)
Date 2023/10/12 17:19:15
Name ArcanumToss
Subject [질문] 자바스크립트 질문 (수정됨)
1.
body에는 다음과 같은 태그를 작성합니다.

<body>
        <img src="1.gif">
        <img src="2.gif">
        ...
        <img src="999999.gif">
</body>


2.
javascript는 대충 다음과 같이 작성합니다.

<script>
window.addEventListener("load", () => {
        imgs = document.getElementsByTagName(`img`);

        for(var i = 0; i < imgs.length; i++){
                imgs[i].addEventListener("click", () => {
                        // 클릭한 element의 this나 index를 알면 되는데...
                        // '1.gif'를 클릭했을 때 실행할 내용.
                        // '2.gif'를 클릭했을 때 실행할 내용.
                        alert("이미지를 클릭함");
                });
        }
});
</script>


이미지를 click하면 "imgs[i].addEventListener("click", ............"이 있으니 click 이벤트를 감지해서 alert("이미지를 클릭함");이 실행됩니다.
여기서 질문입니다.
문제는 '1.gif', '2.gif' 중 어떤 이미지를 눌렀는지 판별할 수 없다는 것입니다.
물론 태그를 다음과 같이 작성하면 되긴 하겠죠?

<img src="1.gif" onclick="img_click(this);">
<img src="2.gif" onclick="img_click(this);">
...
<img src="999999.gif" onclick="img_click(this);">

그리고 이것에 맞춰서 자바스크립트를 다음과 같이 작성하고요.
function img_click(t) {
        alert(t.src);
}

그런데 제가 궁금한 것은 이 방법을 쓰지 않고도 이 방법과 같은 효과를 낼 수 있는 방법입니다.

물론, 편법적으로 imgs[i].outerHTML = imgs[i].outerHTML.replace(`.gif">`, `.gif" onclick="img_click(this);"`)와 같이 하는 방법이 있긴 하겠지만 이렇게 하느니 태그에 onclick="img_click(this);"를 삽입하는 게 훨씬 효율적이겠죠.

idx= [].indexOf.call( imgs, 디스 )와 같은 라인으로 작성하려 해도 디스(this)는 필요한 터라...
방법이 있을까요?
그냥 다음과 같이 작성하는 게 유일한 방법일까요?

<img src="1.gif" onclick="img_click(this);">
<img src="2.gif" onclick="img_click(this);">
...
<img src="999999.gif" onclick="img_click(this);">

통합규정 1.3 이용안내 인용

"Pgr은 '명문화된 삭제규정'이 반드시 필요하지 않은 분을 환영합니다.
법 없이도 사는 사람, 남에게 상처를 주지 않으면서 같이 이야기 나눌 수 있는 분이면 좋겠습니다."
멍충이
23/10/12 17:30
수정 아이콘
imgs[i].addEventListener("click", (e) => {
console.log(e.target.src);
});
ArcanumToss
23/10/12 17:38
수정 아이콘
오!!!!!
e.target
요 방법이 있었군요.
e.src로 안 되길래 모르겠어서 질문을 올렸는데 target를 넣으면 되는 거였다니~~!!!!
하..... 고맙습니다.
긴 씨름이 끝났네요~~~~
23/10/12 17:46
수정 아이콘
본문 내용과는 약간 거리가 있는 내용이긴 하지만 <img> 요소 개수가 많을 경우 각각의 <img> 요소에 일일이 이벤트 리스너를 붙이지 않고, <img> 들을 감싸고 있는 부모 요소 (저기서는 <body>)에만 이벤트 리스너를 붙여도 처리할 수 있습니다.

https://ko.javascript.info/event-delegation

document.body.addEventListener("click", (e) => {
if (e.target.tagName !== "IMG") return;
// event.target으로 원하는 작업 하기
})
ArcanumToss
23/10/12 18:13
수정 아이콘
그렇군요.
if (e.target.tagName !== "IMG") return;
// event.target으로 원하는 작업 하기
})

e.target을 쓰는 방법을 알고 나니 이런 방법도 쓸 수 있다는 걸 알게 되네요.
여러 방법들 중에 제가 만드는 컨텐츠에 가장 효율적인 방법을 좀더 생각해 볼 수 있게 됐습니다.
고맙습니다.
ArcanumToss
23/10/12 19:14
수정 아이콘
이 방법을 테스트 해 보니 img를 누르면 해당 img에 해당하는 기능을 실행하고 img 바깥(div)을 클릭하면 div의 display를 none으로 바꾸는 경우에 쓰면 딱이네요.
이 방법을 알기 전에는 다른 방법으로 구현했었는데 이게 훨씬 심플하군요.
덕분에 더 편한 방법을 찾았네요~ : )
당근병아리
23/10/20 10:37
수정 아이콘
목록 삭게로! 맨위로
번호 제목 이름 날짜 조회
173105 [질문] 네비별로 도착시간 차이가 꽤 큰데 뭐가 정확한가요 [13] 데비루쥐9514 23/10/17 9514
173104 [질문] 베란다에 김치냉장고 설치해도 될까요? [13] 슬론9564 23/10/17 9564
173103 [질문] 마케팅 책 추천 부탁 드려요. [8] realwealth7253 23/10/17 7253
173102 [질문] 주말에 세탁기 사러 가려고 하는데요 [9] Jiny7431 23/10/17 7431
173100 [질문] 실내 러닝화(웨이트 겸용) 추천 부탁드립니다. [9] 밀크티8341 23/10/16 8341
173098 [질문] 혹시 일러스트레이터 한 분만 찾아주실 수 있으려나요 [2] No.99 AaronJudge7342 23/10/16 7342
173097 [질문] 제주도 고등어회 맛집 있을까요? [15] 모찌피치모찌피치8659 23/10/16 8659
173096 [질문] 세금계산서 발행 질문 [5] 리얼포스9104 23/10/16 9104
173095 [질문] LG헬로비전 요거는 쓸만한가요 [8] DogSound-_-*8049 23/10/16 8049
173094 [삭제예정] 꽃밭 이란 용어가 일상생활에서 써도 되는 용어인가요? [32] 삭제됨8692 23/10/16 8692
173093 [질문] 부동산 공부 관련 질문입니다. [11] 리스 제임스8621 23/10/16 8621
173092 [질문] 특이한 알람시계 없을까요? [12] 펩시제로라임7776 23/10/16 7776
173091 [질문] 기화식 가습기(디스크형) 추천 부탁드립니다. [16] 대박7028 23/10/16 7028
173090 [질문] 웨딩 촬영 하는데 팁 있을까요 [19] Alfine7336 23/10/16 7336
173088 [질문] 아이폰 홈화면 가는 방법 [4] phoe菲6889 23/10/16 6889
173087 [질문] 차량 앞 범퍼 손상 이 정도이면 교체가 필요할까요? [19] GoThree9693 23/10/16 9693
173086 [질문] 긴급... 송도에 잘하는 정형외과 있을까요(친한 동생 부상) [9] SAS Tony Parker 7263 23/10/15 7263
173085 [질문] 팔레스타인을 우리나라로 치면? [17] 느나느나타임9154 23/10/15 9154
173084 [질문] 신호위반 차량 신고할 방법이 없을까요? [12] 니체8035 23/10/15 8035
173083 [질문] 향수를 사고싶습니다. [14] 쉬군7560 23/10/15 7560
173081 [삭제예정] 유튜브 시청 관련 질문 [4] 삭제됨6419 23/10/15 6419
173080 [질문] 프리도스 노트북 윈도우 11 다운로드 질문 [7] 소꿉6594 23/10/15 6594
173079 [질문] 베란다 누수 보수 관련 문의드립니다. [2] 허느9545 23/10/15 9545
목록 이전 다음
댓글

+ : 최근 1시간내에 달린 댓글
+ : 최근 2시간내에 달린 댓글
맨 위로