useRef 관련하여 질문드립니다
152
投稿した質問数 5
MyReact.useRef관련하여 질문드립니다
const ref2 = MyReact.useRef();
<input ref={ref}/> 이렇게 사용하면
input태그에 접근할 수 있는데 정확히 어떤 원리로 접근 가능한건가요??
ref2는 원래 undefined값이 아닌가요?
回答 2
0
useRef()로 만든 ref2는 {current: undefined} 값이 할당됩니다. 이 값을 input의 ref 속성에 전달하는데요. react-dom 에서 제공하는 이 특별한 ref 에 의해 ref2.current 에 돔 앨리먼트가 할당되어서 접근할 수 있습니다.
아래 ai 답변도 참고하시면 도움이 될 것 같습니다.
0
안녕하세요, 인프런 AI 인턴입니다. ccccssung님께서 useRef를 통해 DOM 요소에 접근하는 방법 및 원리에 대해 질문하셨군요.
useRef는 React에서 제공하는 훅으로, 컴포넌트의 모든 렌더 동안 불변 참조를 생성할 수 있게 해줍니다. 이 훅은 주로 DOM에 직접 접근하거나 저장하고 싶은 값을 유지할 때 사용됩니다.
useRef의 동작 원리
초기화:
const ref2 = MyReact.useRef();를 호출하면ref2는{ current: null }이라는 객체를 초기값으로 받습니다. 이 객체의current속성은 필요에 따라 변경될 수 있는 값입니다.DOM 요소의 할당: JSX에서
<input ref={ref2} />와 같이 사용하면, 해당 input 요소의 DOM 노드가ref2.current에 할당됩니다. 이로 인해, 컴포넌트가 리렌더링되어도ref2.current는 변경되지 않으며, 항상 동일한 DOM 요소를 가리키게 됩니다.불변성:
useRef를 사용하여 생성된 참조는 컴포넌트가 리렌더링되어도 무효화되지 않습니다. 이는useRef가 참조하고 있는 DOM 요소의 상태를 유지하면서도, 필요할 때 접근할 수 있게 합니다.
한 가지 주의사항
ref.current를 직접 수정하면 리렌더링을 유발하지 않습니다. 따라서 useRef는 DOM 조작이나 외부 라이브러리와 함께 사용할 때 유용합니다.
MyReact에서의 useRef 구현도 참고하시어 직접적으로 어떻게 커서가 작동하는지 확인해보실 수 있습니다.
저는 질문자님의 이해를 돕고자 지식공유자님의 기존 답변을 참고하여 유사한 답변 링크를 추천해드리고 있습니다.
현재 베타 기능으로 답변이 만족스럽지 않을 수 있는 점 양해 부탁드립니다. 🙏
추가적으로 궁금한 점이 있으시면, 이어서 질문해 주세요. 곧 지식공유자께서 답변해 주실 것입니다.
잘못된 useEffect 사용?
1
65
2
useEffect 의존성 질문
1
58
2
orderableProductItem 에 관하여...
0
59
2
강의 자료, 블로그, 깃 주소
0
63
1
React 훅 구현 원리와 실무 패턴 관련 질문 (useState, useEffect 순서 및 핸들러 구조)
1
104
2
pushState로 주소를 바꾸면 렌더링이 안 되는 이유가 궁금합니다.
1
87
2
FormControl 컴포넌트 사용시 htmlFor prop 값 넘길 때 중괄호 이유
1
123
1
dispatch 함수도 리렌더링 유발하지 않나요?
1
204
2
ProductItem에서 onClick = {onClick}을 달지 않아도 되는 이유
1
160
2
replaceState를 쓰지 않는 대안
1
196
2
setValue 메서드를 바인딩 해야 하는 이유
1
163
2
MyReact를 IIFE(즉시실행함수)로 설계하신 이유
0
209
2
[4.4장 메모이제이션 훅] 4.4.3 memo 참조 비교
0
130
1
렌더 프롭 관련하여 질문드립니다
0
183
2
[1.2장 상품목록 화면] 1.2.3 Button ...rest 관련 질문 드립니다.
1
395
2
[4.4장 메모이제이션 훅] 4.4.4 useCallback curried function에 관한 질문입니다.
1
318
2
[4.4장 메모이제이션 훅] 4.4.2 useMemo 에서 every 함수에 관한 질문입니다.
1
356
2
[4.3장 리듀서 훅] 4.3.7 활용 MyForm(풀이) 오타 제보 및 질문이 있습니다.
1
281
2
[4.1장 레프 훅] useRef관련 질문이있습니다.
1
334
1
[1.3장 주문 내역 화면] 1.3.5 Card 조합 질문 있습니다
2
284
1
[3.5장 컨택스트 훅] 3.5.2 useContenxt 에서 질문이 있습니다.
1
432
2
[1.3.6 상태정의] state 관련
1
259
1
[2.4장 다이얼로그 1] 2.4.5 withLayout(풀이) 에 관한 질문입니다.
1
272
1
[2.1장 컨택스트] 2.1.4 공급자와 소비자 / 에서 질문이 있습니다.
1
425
2

