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

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



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


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님의 댓글"

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

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