상식닷컴
로그인
가입하기
2026년 상식닷컴 선정 식당 & 카페 리스트
2025년 2026년 신상 호텔 리스트
최근에 오픈한 호텔을 찾는다면 살펴보세요
일주일 식단표 어플
자동 일주일 식단표 어플
안드로이드
아이폰
주식 & 코인 차트의 신
1000만원으로 2000만원 만들기 프로젝트
수정하기 - React에서 useRef 훅의 용도는 무엇인가요?
닉네임
비밀번호
제목
내용
[이미지 업로드는 권한이 있는 사람만 가능. 하단 카톡으로 연락]
`<a href='https://sangseek.com/sangseeks/useRef/ko'>useRef</a>` 훅은 React에서 DOM 요소에 직접 접근하거나, 컴포넌트의 상태를 유지하기 위해 사용되는 훅입니다. 이 훅은 React의 <a href='https://sangseek.com/sangseeks/함수형/ko'>함수형</a> 컴포넌트에서 mutable한 값을 저장할 수 있는 방법을 제공합니다. `useRef`는 주로 다음과 같은 용도로 사용됩니다. 1. DOM 요소에 접근하기 `useRef`는 특정 DOM 요소에 대한 참조를 생성할 수 있습니다. 이를 통해 React 컴포넌트 내에서 해당 요소에 직접 접근하고 조작할 수 있습니다. 예를 들어, 입력 필드에 포커스를 주거나, 특정 요소의 크기를 측정하는 등의 작업을 할 수 있습니다. ```javascript import React, { useRef } from 'react'; const FocusInput = () => { const inputRef = useRef(null); const handleFocus = () => { if (inputRef.current) { inputRef.current.focus(); } }; return ( <div> <input ref={inputRef} type="text" /> <button onClick={handleFocus}>Focus the input</button> </div> ); }; ``` 위의 예제에서 `inputRef`는 `<input>` 요소에 대한 참조를 저장하고, 버튼 클릭 시 해당 입력 필드에 포커스를 주는 기능을 구현하고 있습니다. 2. 상태 유지 `useRef`는 렌더링 간에 값을 유지할 수 있는 방법을 제공합니다. 일반적으로 상태를 관리할 때는 `useState`를 사용하지만, `useRef`는 렌더링을 트리거하지 않고도 값을 저장할 수 있습니다. 이는 <a href='https://sangseek.com/sangseeks/성능 최적화/ko'>성능 최적화</a>에 유리할 수 있습니다. ```javascript import React, { useRef } from 'react'; const Timer = () => { const countRef = useRef(0); const handleIncrement = () => { countRef.current += 1; console.log(countRef.current); }; return ( <div> <button onClick={handleIncrement}>Increment</button> </div> ); }; ``` 위의 예제에서 `countRef`는 버튼 클릭 시마다 증가하는 값을 저장합니다. 이 값은 렌더링에 영향을 주지 않기 때문에, 컴포넌트가 다시 렌더링될 때 이전 값이 유지됩니다. 3. 이전 상태 값 접근 `useRef`를 사용하여 이전 상태 값을 저장하고 접근할 수 있습니다. 이를 통해 컴포넌트의 상태 변화에 따른 이전 값을 쉽게 추적할 수 있습니다. ```javascript import React, { useEffect, useRef, useState } from 'react'; const PreviousValue = ({ value }) => { const prevValueRef = useRef(); useEffect(() => { prevValueRef.current = value; }, [value]); return ( <div> <p>Current Value: {value}</p> <p>Previous Value: {prevValueRef.current}</p> </div> ); }; ``` 이 예제에서는 `value` prop의 이전 값을 `prevValueRef`를 통해 저장하고, 이를 화면에 표시합니다. 4. 성능 최적화 `useRef`는 렌더링을 트리거하지 않기 때문에, 성능 최적화에 유리합니다. 예를 들어, 대량의 데이터를 처리하거나, 자주 업데이트되는 값을 관리할 때 `useRef`를 사용하면 불필요한 렌더링을 방지할 수 있습니다. 결론 `useRef`는 React에서 매우 유용한 훅으로, DOM 요소에 대한 직접적인 접근, 상태 유지, 이전 값 추적, 성능 최적화 등 다양한 용도로 활용될 수 있습니다. 이를 통해 개발자는 더 효율적이고 직관적인 컴포넌트를 작성할 수 있습니다. `useRef`를 적절히 활용하면 React 애플리케이션의 성능과 사용자 경험을 향상시킬 수 있습니다.
이용안내
커뮤니티 이용안내
×
- 게시한 게시글로 발생하는 문제는 게시자에게 책임이 있습니다.
- 게시글이 타인/타업체의 저작권을 침해할 경우 모든 책임은 게시자에게 있습니다. 게시자가 모든 손해를 부담해야 합니다.
- 상식닷컴 운영자는 게시자와 상의하지 않고 게시글을 수정 또는 삭제할 수 있습니다.
- 상식닷컴 운영자는 깨끗한 커뮤니티 공간을 만드는 것이 1순위입니다.
수정하기
취소하기