• 목록
  • 아래로
  • 위로
  • 2
  • Hanam09
  • 조회 수 281
<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님의 댓글"

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

권한이 없습니다.
번호 제목 글쓴이 날짜 조회 수
공지 [작업 완료] 설 명절 맞이 서버 업데이트 안내 3 마스터 24.02.11.17:21 1182
공지 [중요] 호스팅 만료와 관련하여 일부 수칙이 변경됩니다. 4 마스터 23.01.14.02:23 4871
공지 [필독] 질문하는 방법 17 마스터 18.02.23.03:09 4485
206 htaccess 파일 관련 질문입니다. 2 Seia 18.01.13.07:59 269
205 [404&403 에러] 흑흑 2 image 260578 18.04.10.22:00 286
204 크롤링 머신(미니PC) 세팅과 관련하여 질문 드립니다 2 이니스프리 19.10.14.20:23 507
203 curl: (7) Failed to connect to localhost port 80: Connection refused 2 image 국내산라이츄 22.07.25.15:57 1581
202 TTFB 2 image Apache 20.07.14.22:07 173
201 그매햇던것이 라이믹스 에 안올라갑니다. 2 image 핫슈 20.06.19.20:52 73
200 [라이믹스] 스킨 설치가 안됩니다. 2 260578 20.12.31.08:43 111
199 프로그래머스 코딩테스트 연습에서 효율성 심사를 통과하려면 어떻게 해야할까요? 2 이니스프리 19.12.18.01:55 2867
198 사이트 정보 등록 2 title: 크롬NUBE 19.01.19.16:11 194
197 CentOS vsftp 윈도우 클라이언트에서 접속 불가 2 image 세종대왕 20.09.09.14:04 76
아이고 자바스크립트 고수분들 도와주세요!!! 2 Hanam09 18.01.08.23:03 281
195 호스팅 사용중 연장 질문 2 퓨처마츠 18.10.03.19:29 166
194 나무위키 포크 위키 만들기 2 아엠이언맨 19.06.07.11:37 274
193 코로케이션은 어디가 좋을까요? 2 Ilhan 18.04.28.22:40 209
192 스포어 호스팅 관련.. 2 Tilto_ 18.08.21.21:00 270
191 실험실 공유기의 상태가 실로 이상하네요. 2 국내산라이츄 17.10.27.14:20 216
190 참 아이러니한 일이 발생햇습니당 2 image title: 도밥위키!Dobob 17.02.07.23:20 395
189 유튜브 채널 주소 잘아시는분있나요? 2 슬기 19.12.27.09:55 187
188 ReactJS 도와주세요! 2 image Hanam09 20.01.25.22:01 176
187 Beautifulsoup에서 .find(text=True, recursive=False)과 관련하여 질문 드립니다. 2 이니스프리 20.01.03.23:11 1151