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
수정 아이콘
목록 삭게로! 맨위로
번호 제목 이름 날짜 조회
173049 [질문] 사이버포뮬러 시리즈 다시보는 방법 [6] 큭큭나당7925 23/10/12 7925
173048 [질문] 부산 경남 인근 가볍게 즐길수 있는 캠핑장 찾습니다 파르셀6513 23/10/12 6513
173047 [질문] 게임용 패드를 써보고 싶은데 추천받을 수 있을지 [9] HA클러스터8419 23/10/12 8419
173046 [질문] 자바스크립트 질문 [6] ArcanumToss7188 23/10/12 7188
173045 [질문] 청중 상대로 PPT 하며 모바일로 의견 주고 받고 할 수 있는 서비스가 무엇인가요? [4] 7950 23/10/12 7950
173044 [질문] 사무용품 추천 부탁드립니다. [13] 장헌이도7659 23/10/12 7659
173043 [질문] 매입한 토지에 창고를 짓는건 상관없나요?? [14] 8억빠8664 23/10/12 8664
173042 [질문] 마트나 편의점에서 살 수 있는무난한 와인 추천부탁합니다. [17] 언니네 이발관7995 23/10/12 7995
173041 [질문] 상가임대차 보호법 적용 기준이 넘으면 임차인이 보호 받을 방법이 없나요? [1] LG의심장박용택6808 23/10/12 6808
173040 [질문] 이사에 따른 각종 주소 변경을 자동으로? [3] Scarecrow5798 23/10/12 5798
173039 [질문] 퇴사시 건강보험,4대보험 처리 질문 [6] 김리프8840 23/10/12 8840
173038 [질문] 실업급여 받아보신분 계신가요? [18] 라리8489 23/10/12 8489
173037 [질문] 특정질병에만 대비한 보험가입이란것이 가능할까요? [3] 찹쌀탕수육6571 23/10/12 6571
173036 [질문] 혹시 베지밀스타는 pgr에서 돌던 내수용 유머였을까요? [8] 스물다섯대째뺨8730 23/10/12 8730
173035 [질문] a매치 하는날 상암경기장 주차가 가능한가요? [9] 진아린롱7379 23/10/11 7379
173034 [질문] 공유기 질문이요 [3] 메롱약오르징까꿍7405 23/10/11 7405
173033 [질문] 맛집 가고 싶은데 같이 갈 사람이 없을때 [10] 삭제됨8064 23/10/11 8064
173032 [질문] 파일 옮길 때 이름 중복시 자동으로 바꾸는 방법은 없나요? [2] wook986342 23/10/11 6342
173031 [질문] 허리디스크에 근력운동이 맞나요? [16] 탄야9279 23/10/11 9279
173029 [질문] 8년차 노트북에겐 세상이 이렇게 힘든걸까요? [9] 바쿠8613 23/10/11 8613
173027 [질문] 부산 출발 패키지 시드니 괜찮을까요?? [4] 콩순이7981 23/10/11 7981
173026 [질문] 나무위키 수정을 하고 싶습니다. [3] 분당선7203 23/10/11 7203
173025 [질문] 병원 어느과를 가야할까요? [7] 마인부우7363 23/10/11 7363
목록 이전 다음
댓글

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