• 목록
  • 아래로
  • 위로
  • 2
  • Hanam09
  • 조회 수 686
<div id="Error">
<div hc-element="block"></div>
<img width="150px" hc-float="center" src="img/Warning.svg.png">
<center>
<h2>Oops, Access to this page has been denied!</h2>
<button hc-event="back" hc-float="center">back</button>
</center>
<div hc-element="block"></div>
</div>


문제가 되는 웹: gift.ihnkyou.gq

소스보기: view-source:gift.ihnkyou.gq

해당파일 : htmlctr.js

버튼이 작동하지 않습니다. 문제가 있는거 같은데 찾지는 못하겠습니다. 

무엇이 문제인지 알려주실 수 있습니까?

저기 위에건 html 소스라서 못읽습니다. 

이 문제를 해결하기 위하여 제가 어떻게 하여야 할까요?

작성자
Hanam09 36 Lv. (50%) 106610/109520EXP

 

안녕!

 

댓글 2

네모
profile image

Inv['plugin']['event'] 에 정의된 함수에 문제가 있습니다.

 

for(var i = 0; i < Inv.getElements('event').length; i++){

    Inv.getElements('event')[i].onclick = function() {

        if(Inv.getValue("event", i) === "refresh")

            location.reload();

    }

}

 

 

여기서 Element.onclick 함수 안에서 i 변수를 사용하셨는데,

반복문에서 사용되는 반복카운터는 함수 안에서 사용하시면 안됩니다.

 

저 i 값은 클로져 변수라 for 블럭 안에서만 사용되는 것은 맞으나, 그것이 반복할 때마다 새롭게 생성되는건 아닙니다.

이전에 실행되었던 반복코드에서도 i 값에 접근한다면, 돌아오는 값은 지금까지 진행된 카운트 수가 됩니다.

예를 들어, for(i = 0 to 10) { setTimeout( { alert(i) }, 1000); } 이라는 의사코드를 실행한다면,

출력되는 값은 어지간한 조선컴퓨터가 아닌 이상 10 이라는 숫자가 10회 출력된다는 것이죠.

 

 

하남님이 원하시는(또는 그렇게 추정되는) 방식으로 구현하려면,

저 i 값을 보존하는 변수를 하나 더 만들어서, 그 변수를 i 대신 사용해야겠죠.

 

for(var i = 0; i < Inv.getElements('event').length; i++){

    var ti = i;

    Inv.getElements('event')[ti].onclick = function() {

        if(Inv.getValue("event", ti) === "refresh")

            location.reload();

    }

}

 

같은 느낌으로요.

 

솔직히, 제가 생각하기에는 그리 이상적인 방법은 아니라고 생각합니다.

요즘 PC에서는 웬만해선 부담되지 않겠지만, 그래도 많은 Element 들이 생긴다면, 부담이 될겁니다.

해당 Attribute 가 있는 개수만큼 변수를 생성해버릴테니까요.

 

저라면 getValue 에서 사용 가능한 파라미터 종류를 하나 더 만들듯 싶네요.

파라미터의 타입이 Element 라면, getElement를 거치지 않고, 바로 파라미터에서 Attribute를 가져오는 식으로요.

comment menu
2018.01.09. 01:23

신고

"네모님의 댓글"

이 댓글을 신고 하시겠습니까?

Hanam09 작성자 → 네모
profile image

오!!!! 정성스러운 답변 정말로 감사합니다^^!!

네모님 덕분에 문제를 알 수 있었습니다! 

복많이 받으세요!!

comment menu
2018.01.09. 15:47

신고

"Hanam09님의 댓글"

이 댓글을 신고 하시겠습니까?

권한이 없습니다.
번호 제목 글쓴이 날짜 조회 수
공지 시스템 점검 작업 완료 안내 10 마스터 24.09.05.16:25 2570
공지 [중요] 호스팅 만료와 관련하여 일부 수칙이 변경됩니다. 4 마스터 23.01.14.02:23 10013
공지 [필독] 질문하는 방법 17 마스터 18.02.23.03:09 4944
666 리디렉션 형태가 여러가지가 있던데 설명좀 해주실분 계신가요? 4 참빛바다 18.01.01.20:00 476
아이고 자바스크립트 고수분들 도와주세요!!! 2 Hanam09 18.01.08.23:03 686
664 변수를 앞에다가 위치시켰는데 500 에러가 뜹니다.. 5 260578 18.01.10.13:10 573
663 에.. 죄송합니다. 이번이 세번째 질문이네요. 2 260578 18.01.11.16:31 595
662 윈도우용 메일 클라이언트가 필요합니다. 9 네모 18.01.11.20:15 5906
661 첨부 파일의 디자인을 변경하고 싶은데... 6 image title: 대한민국 국기Adam 18.01.12.08:53 750
660 무언가가 이상합니다. 3 260578 18.01.12.11:35 392
659 Cloudflare ssl 사용하려면 패널에서 따로 해줘야 할 것이 있나요? 2 참빛바다 18.01.12.11:57 313
658 htaccess 파일 관련 질문입니다. 2 Seia 18.01.13.07:59 440
657 워드프레스 호스팅 하는데 막혔습니다... 19 image MYIG 18.01.18.01:14 560
656 도메인 연장이 고민입니다. 3 260578 18.01.20.12:03 581
655 으앜! 살려주세요 7 title: 도밥위키!Dobob 18.01.20.19:22 342
654 SSL 관련 3 Seia 18.01.21.02:50 531
653 studyforus.com이 CNAME으로 연결이 되는 군요. 9 Seia 18.01.21.02:54 491
652 RSA 암호화를 구현하려고 하는데.... 7 Hanam09 18.01.24.14:20 610
651 어른패드의 상태가 이상합니다. 2 국내산라이츄 18.01.29.05:13 493
650 [완료] 사이트에 웹폰트를 추가하고 싶습니다. 14 image 제르엘 18.01.31.14:51 507
649 보안 오류 13 Hanam09 18.02.03.11:14 519
648 라이센스 표기 7 준그루 18.02.03.18:49 660
647 클론질라 dhcp서버 질문입니다 ㅠㅠ 14 크로스하트 18.02.05.18:47 620