• 목록
  • 아래로
  • 위로
  • 6
  • 홀민
  • 조회 수 217

제가 자바스크립트를 잘몰라서 원론적인 질문 하나 드립니다.



다음 지도 코드 작성중입니다.


daum.maps.event.addListener(map, 'dragend', function() { // 맵이 이동 되면 맵정보를 다시 읽어옵니다.
    getInfo(); // 맵정보를 읽어옴
});


이런코드를 짜게 되었는데요.. 이유를 모릅니다.


function() 이 변수로 들어가있는데요.

getInfo()함수를 직접 넣으니 오류가 납니다.


function() 는 대체 먼가요?

함수 이름도 없고.....그냥 함수를 호출 하는데 그 함수는 {} 안의 함수다.


이런 뜻인가요?


만약 그렇다면 왜 함수를 직접 넣으면 오류가 나게 되나요?

자바스크립트는 함수를 변수로 취급 할수 있다고 알고 있는데.

함수는 저런식으로 넣어야 하는건지..

그냥 쓰기만 해서 ... 대체 왜 그런지 궁금하네요.


아시는 분 답변 부탁드립니다.

댓글 6

title: 황금 서버 (30일)humit
profile image

function() 의 경우에는 이름이 없는 익명함수입니다.

그리고 해당 구문에 대해서는 콜백 함수로 검색을 하시면 아실 수 있습니다.

 

참고로 아래와 같이 사용하시면 동일한 결과를 얻으실 수 있습니다.

daum.maps.event.addListener(map, 'dragend', getInfo);

 

comment menu
2018.12.06. 11:51

신고

"humit님의 댓글"

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

홀민 작성자 → humit
profile image

http://victorydntmd.tistory.com/

 

휴...너무 많은 글을 읽었습니다.

다 소화시키지도 못하겠지만. 읽다보니 계속 글을 타고 따라가게 되어서....

여튼 위에 페이지 좋네요.

 

답변 감사하고 배울것을 많이 알게 되었습니다.

 

말해주신 코드는 내일 한번 시도해보도록 할께요.

감사합니다.

comment menu
2018.12.07. 01:21

신고

"홀민님의 댓글"

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

홀민 작성자 → 홀민
profile image

정말 잘 동작하네요.

---

daum.maps.event.addListener(map, 'dragend', getInfo()) ;

이렇게 넣으면 동작하지 않으면서

daum.maps.event.addListener(map, 'dragend', getInfo) ;

이렇게하면 왜 동작하는걸까요...?

혹시 알려주실수 있으신가요?

이름만 넣으면 콜백함수로 되는거 같은데..

 

 

다시한번 감사합니다.

comment menu
2018.12.07. 07:48

신고

"홀민님의 댓글"

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

Hanam09 → 홀민
profile image

안녕하세요 대신답변하겠습니다.

 

이벤트리스너에서 이벤트가 발생될때 이벤트 함수가 실행 (Event())되게 됩니다. 

한가지 예를 들어보죠




var Event = function(){

    console.log("함수를 실행하셨습니다.");

}




Event라는 함수를 정의하였습니다.


이제 이 함수를 호출하려면 어떻게 해야할까요?




Event()




라는 코드를 실행해야합니다.


만약 




Event




라는 코드만 쓰면 어떻게 될까요?




 function(){

    console.log("함수를 실행하셨습니다.");

}




브라우져는 이런 값을 반환합니다.

정의된 함수만을 보여주는 거죠..


이 함수를 실행시키려면




(function(){

    console.log("함수를 실행하셨습니다.");

})();




이렇게 해야합니다. 괄호(실행자)가 붙어야하죠.


브라우져에 이런 코드를 넣어보세요




function(){

    console.log("함수를 실행하셨습니다.");

}



이 함수는 실행되지 않습니다. 실행자가 없기 때문이죠.


이벤트 리스너는 미리 호출할 함수를 정의만 해두고 이벤트가 일어날때마다 정의된함수를 호출해줍니다.




익명함수에서 addEventListener을 사용하면 (function(){}) 이런 익명함수 이벤트가 실행 (function(){})() 되게 됩니다.

근데 X.addEventListener(x,evt,callback()) 이렇게 하게되면 이벤트가 발생될때 (function(){}())() 이런 요상한게 실행되면서 타입에러가 발생됩니다.

comment menu
2018.12.08. 15:20

신고

"Hanam09님의 댓글"

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

홀민 작성자 → Hanam09
profile image

그러면 결론적으로 익명함수에서 함수를 호출하려면 함수 호출 () 를 생각한채 함수 이름만으로 호출해야된다는 말이되네요..

제대로 이해하려면 자바스크립트를 깊이 있게 공부해야되는군요.

설명 감사합니다.

comment menu
2018.12.09. 16:23

신고

"홀민님의 댓글"

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

Hanam09 → 홀민
profile image

네, 미리 함수를 정의만 해두어야 합니다.

 

감사합니다.

comment menu
2018.12.10. 18:54

신고

"Hanam09님의 댓글"

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

권한이 없습니다.
번호 제목 글쓴이 날짜 조회 수
공지 [작업 완료] 설 명절 맞이 서버 업데이트 안내 3 마스터 24.02.11.17:21 1061
공지 [중요] 호스팅 만료와 관련하여 일부 수칙이 변경됩니다. 4 마스터 23.01.14.02:23 4738
공지 [필독] 질문하는 방법 17 마스터 18.02.23.03:09 4483
306 키보드 트레이가 달린 컴퓨터 책상 추천을 부탁드립니다 2 이니스프리 18.03.18.21:40 1167
305 경험치와 포인트가 안올라갑니다. 6 칸달프 18.03.18.18:42 192
304 나무 위키의 수익구조는 무엇일까요? 2 NoYeah 18.03.18.15:56 3845
303 서브도메인은 뭐가 뭔지 하나도 모르겠습니다.. 5 image 260578 18.03.18.14:59 222
302 파일질라 파일 편집시 자동업로드 활성화 방법 3 image 네모 18.03.14.15:25 1889
301 [미디어위키] 밑의 글 답변 내용으로해도 작동하지 않습니다. (계속 질문글 올려 죄송합니다.) 3 image 260578 18.03.11.19:58 261
300 [미디어위키] 비밀번호 재설정 (SMTP) 기능이 작동하지 않음 1 260578 18.03.03.19:37 262
299 무슨 문제일까요 3 image 260578 18.03.03.09:32 181
298 동영상 플레이어 2개 이상 깔때 코덱 질문드립니다. 2 크로스하트 18.03.02.18:04 172
297 이메일 설정이 안됩니다.. 3 image 260578 18.03.01.18:09 187
296 미디어위키 리버티 스킨 도구 설정 1 image 박재식품 18.02.28.12:36 436
295 미디어 위키 닷홈 MySQL 설정하는법 도와주세요 1 image AA 18.02.27.23:47 701
294 혹시.. 3 막시모 18.02.27.15:13 177
293 음..... 3 박재식품 18.02.26.21:41 174
292 미디어위키 외부의존성 오류 image 박재식품 18.02.26.18:34 188
291 SSL 문제 3 박재식품 18.02.26.16:03 182
290 403오류 2 image 박재식품 18.02.26.13:04 342
289 읔! 스포어 PW는 어디서 바꿔야할까요? 1 title: 도밥위키!Dobob 18.02.26.08:24 169
288 이 부품들로 개인 서버 구축 가능할까요? 17 제르엘 18.02.25.16:29 311
287 도메인 입력해도 Study For Us 홈페이지로 리다이렉팅 됩니다. 8 Nerd 18.02.17.14:55 235