• 목록
  • 아래로
  • 위로
  • 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 602
공지 [중요] 호스팅 만료와 관련하여 일부 수칙이 변경됩니다. 4 마스터 23.01.14.02:23 4283
공지 [필독] 질문하는 방법 17 마스터 18.02.23.03:09 4471
822 Set up the wiki 18 Whitetiger0423 20.12.07.10:37 437
821 홈페이지 디자인을 바꾼 후부터 게시판 스킨 적용이 이상하게 됩니다 image 손가락개 20.12.04.02:56 66
820 혹시 FTP 접속 잘 되시나요?? 2 원미 20.12.01.21:51 101
819 카페대문 만들기 힘드네요 .. 공구테라스 20.11.26.16:24 103
818 php 관련해서 질문 좀 여쭙겠습니다 image title: 대한민국 국기gimmepoint 20.11.23.20:50 109
817 [CSS] 애니메이션 관련 4 260578 20.11.21.23:24 116
816 요즘 코로나 백신 소식이 자주나오는데 내년에는 괜찮을까요? 3 필우 20.11.13.10:41 74
815 ftp web파일 1 wikiowner 20.11.11.22:16 57
814 중고 모니터 액정이 나갔는데 수리하는게 나을까요? 새로 사는게 나을까요? 10 필우 20.11.11.10:47 137
813 폴더 권한 관련 질문 드립니다. 5 image 이니스프리 20.11.08.14:47 94
812 맵네임을 누르면 다른 사이트의 게시판을 나오게 하고싶은데 어떻게 해야하나요? 1 손가락개 20.11.08.01:01 51
811 위키 설치 하실줄 아시는분,,,, 2 wikiowner 20.11.06.20:30 133
810 FTP 연결 안됌.... 2 image wikiowner 20.11.06.19:18 78
809 도메인 싸거나 공짜로 파는 곳 어디 있을까요 6 출사로 20.11.06.07:22 261
808 위키 호스팅에 대해 궁금점 9 wikiowner 20.11.04.15:05 131
807 사이트 정보 등록 3 citen 20.10.29.17:36 84
806 키보드 트레이 추천을 부탁드려요 ^^ 3 이니스프리 20.10.29.00:05 121
805 재질문) php 오류페이지 관련 질문입니다 2 Ruwaku 20.10.13.20:54 153
804 이거 서비스센터 가야 하는 부분인가요? 8 국내산라이츄 20.10.07.14:44 107
803 배터리 수명 단축을 가속화시키는 법이 있을까요? 11 image 제르엘 20.10.04.23:02 358