inflearn logo
강의

강의

N
챌린지

챌린지

멘토링

멘토링

N
클립

클립

로드맵

로드맵

지식공유

한 입 크기로 잘라 먹는 리액트(React.js) : 기초부터 실전까지

onClick 사용시 질문입니다!

335

eko09

작성한 질문수 17

0

onClick를 이용할경우 onClick= { ( ) => ?? } 해당 형식으로 사용해야하는 경우가 있고 아닌경우가 있는데 헷갈리네요 ㅜㅜ

클릭할떄 실행되는함수가 파라미터를 받지않는다면 onClick={함수명} 이런식이고

파라미터를 받는다면 onClick={( )=>함수명( 파라미터 )} 이런식인거같은데 다른경우도 있을까요?? 콜백 함수에 관한 영상을 찾아보면 이해가 될까요??

 

javascript react node.js

답변 2

0

이정환 Winterlood

안녕하세요 이정환입니다.
onClick과 같은 on 접두사가 붙은 이벤트핸들러를 사용할 때에는
"함수 자체를 Props로 전달한다" 또는 "콜백함수로 전달한다"라는 느낌으로 전달하시면 됩니다.

따라서 아래의 형태를 비교해보시면 이해하시기 보다 쉬울겁니다.

  1. ❌ onClick={someFunction()}

  2. ✅ onClick={someFunction}

  3. ✅ onClick={() => {someFunciton()}}

  4. ✅ onClick={()=>someFunction()}

1번의 경우 someFunction 함수를 이벤트 핸들러로 전달하는게 아니라, someFunction 함수의 결과값을 이벤트 핸들러로 전달하고 있기 때문에 이렇게 하시면 안됩니다.

0

인프런 AI 인턴

안녕하세요, 인프런 AI 인턴입니다.

onClick 이벤트를 사용할 때에는 일반적으로 클릭할 때 실행될 함수를 지정해줍니다.
만약 클릭 이벤트에 함수가 파라미터를 받지 않는다면 onClick={함수명} 형식으로 사용하시면 됩니다. 이때 함수는 클릭 이벤트가 발생할 때 자동으로 실행됩니다.

하지만 클릭 이벤트에 함수가 파라미터를 받아야 한다면 onClick={() => 함수명(파라미터)} 형식으로 사용하시면 됩니다. 이때 괄호 안에 파라미터를 넣어주시면 클릭 이벤트가 발생할 때 해당 함수와 파라미터가 함께 실행됩니다.

콜백 함수에 대한 자세한 이해를 돕기 위해 콜백 함수에 관한 영상을 찾아보는 것도 좋은 방법입니다. 온라인 프로그래밍 컨텐츠나 자바스크립트 관련 포럼에서 자세한 설명을 찾아보시면 도움이 될 것입니다.

추가적으로 리액트에서 onClick 이벤트 사용 시에는 이벤트 핸들러를 바로 작성하는 것이 아니라, 함수를 전달하는 방식을 권장합니다. 이유는 함수를 전달하면 불필요한 리랜더링이 발생하지 않기 때문입니다.

더 궁금한 점이 있다면 언제든지 물어보세요. 좋은 하루 보내세요!

eslint.config.js 설정 질문입니다.

0

6

1

존재하지 않는 일기 url입력 시 alert이 두 번 떠요

0

43

1

교재(3쇄)와 강의 내용 문의

0

39

2

12.13) 하단 여백 스타일링 관련 질문 드립니다.

0

70

2

에러 질문드립니다

0

65

2

VSCode 설정 문의

0

77

2

PPT 코드 관련 질문

0

51

2

useEffect와 lifecycle문의

0

70

2

프론트엔드 학습 수준 문의

0

84

2

리액트 챕터별 코드에서 eslint 설정파일이 없어요

0

78

2

데이터 로딩중 화면만 계속 나와요!!

0

74

2

퍼블리셔일경우 어느정도 수준까지 강의를 들어야할까요

0

107

2

이후의 커리큘럼 문의

0

130

2

실슬환경 설정에서 save후 console.log 부분이 새로고침이 안되는현상입니다.

0

76

2

최적화 관련 질문있습니다 (useMemo 등)

0

106

3

프로바이더 컴포넌트의 위치는 어떤 기준인가요?

1

98

3

Date 객체에 관련하여 질문드립니다.

0

100

2

리액트 개정판 교재 질문

0

77

2

예제코드가 안나와요!

0

87

2

select a variant 선택에서 javascript와 javascript+react compiler 중 무엇을 선택해야하나요? com

0

134

2

onMouseEnter 관련 문의 드립니다

0

112

3

배열의 렌더링 관련 질문 드립니다.

0

87

2

2:40초 refObj를 콘솔로 출력시 오류가 발생합니다.

0

139

2

TS, 리액트 강의중에 뭘 먼저 수강하는게 좋을까요?

0

160

2