상식닷컴
로그인
가입하기
2026년 상식닷컴 선정 식당 & 카페 리스트
2025년 2026년 신상 호텔 리스트
최근에 오픈한 호텔을 찾는다면 살펴보세요
일주일 식단표 어플
자동 일주일 식단표 어플
안드로이드
아이폰
주식 & 코인 차트의 신
1000만원으로 2000만원 만들기 프로젝트
궁금한 상식 보기
프로세코의 원산지는 어디인가요?
솔라닌은 어떤 식물에서 발견되나요?
급한 성격이 팀워크에 미치는 영향은 무엇인가요?
아랍 요리에서 가장 유명한 디저트는 무엇인가요?
아랍식 요리에서의 건강한 재료는 무엇인가요?
안전벨트의 착용이 교통사고 예방을 위한 기술적 발전에 미치는 영향은?
안전벨트의 착용이 교통사고 발생 시 생존 가능성에 대한 인식에 미치는 영향은?
키 크는 데 도움이 되는 건강한 간식은 무엇인가요?
키 크는 데 도움이 되는 운동 동기 부여 방법은 무엇인가요?
한나라의 주요 문학 작품은 무엇이 있나요?
진나라의 정치적 개혁은 어떤 것이 있었나요?
진나라의 군사 동맹은 어떤 것이 있었나요?
Previous
Next
수정하기 - 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순위입니다.
수정하기
취소하기