React의 Ref와 DOM 이해: DOM 요소 액세스 및 조작
React의 Ref와 DOM: DOM 요소 액세스 및 조작
React에서 refs는 DOM 요소에 직접 액세스하고 상호 작용하는 데 사용됩니다. React는 일반적으로 상태와 소품을 통해 선언적인 방식으로 DOM을 관리하지만 애니메이션, 양식 필드 포커스 또는 요소 크기 측정과 같이 DOM과 직접 상호 작용해야 하는 경우가 있습니다. 이러한 경우 참조는 기본 DOM 노드에 액세스하는 방법을 제공합니다.
1. React의 Ref는 무엇인가요?
ref(reference의 약자)는 DOM 요소나 React 구성 요소 인스턴스를 참조할 수 있는 객체입니다. Ref는 클래스 컴포넌트에서 React.createRef()를 사용하거나 함수 컴포넌트에서 useRef()를 사용하여 생성할 수 있습니다. Refs는 일반적으로 다음 용도로 사용됩니다.
- DOM에 직접 액세스합니다(예: 입력 필드에 초점을 맞추거나 양식 요소의 값 가져오기).
- 명령형 애니메이션이나 액션을 트리거합니다.
- 직접 DOM 조작이 필요한 타사 라이브러리와 통합하세요.
2. Ref 생성 및 사용
클래스 구성요소:
클래스 컴포넌트에서는 React.createRef()를 사용하여 참조를 생성합니다. 생성된 참조는 ref 속성을 통해 DOM 요소에 첨부됩니다.
클래스 구성요소의 참조 예:
import React, { Component } from 'react'; class MyComponent extends Component { constructor(props) { super(props); // Create a ref to access the input element this.inputRef = React.createRef(); } handleFocus = () => { // Access the DOM node directly and focus the input element this.inputRef.current.focus(); }; render() { return ( <div> <input ref={this.inputRef} type="text" /> <button onClick={this.handleFocus}>Focus Input</button> </div> ); } } export default MyComponent;
이 예에서는:
- this.inputRef는 React.createRef()를 사용하여 생성됩니다.
- 참조는 ref 속성을 통해 요소를 삭제합니다.
- handleFocus 메소드에서는 this.inputRef.current를 통해 입력 요소에 액세스하고 focus()를 호출하여 입력 필드에 프로그래밍 방식으로 초점을 맞춥니다.
기능 구성요소:
함수 구성 요소에서는 useRef 후크를 사용하여 참조가 생성됩니다. useRef 후크를 사용하면 다시 렌더링할 때에도 지속되는 변경 가능한 참조 객체를 생성할 수 있습니다.
기능 구성 요소의 참조 예:
import React, { useRef } from 'react'; const MyComponent = () => { const inputRef = useRef(); const handleFocus = () => { // Access the DOM node directly and focus the input element inputRef.current.focus(); }; return ( <div> <input ref={inputRef} type="text" /> <button onClick={handleFocus}>Focus Input</button> </div> ); }; export default MyComponent;
이 예에서는:
- inputRef는 useRef 후크를 사용하여 생성됩니다.
- 참조는 ref 속성을 사용하는 요소입니다.
- handleFocus 함수는 inputRef.current를 사용하여 입력 요소에 액세스하고 focus()를 호출하여 입력 필드에 초점을 맞춥니다.
3. 참조 사용 사례
아. DOM 요소 액세스
Ref는 일반적으로 DOM 요소에 직접 액세스하고 조작하는 데 사용됩니다. 예를 들어 텍스트 입력에 초점을 맞추거나 요소의 크기를 측정하는 것은 참조를 사용하여 쉽게 수행할 수 있습니다.
ㄴ. 집중력 관리
Ref를 사용하면 구성요소가 마운트될 때 또는 특정 작업 후에 입력 필드에 초점을 맞추는 등 요소에 대한 초점을 관리할 수 있습니다.
Ref를 사용한 포커스 관리의 예:
import React, { Component } from 'react'; class MyComponent extends Component { constructor(props) { super(props); // Create a ref to access the input element this.inputRef = React.createRef(); } handleFocus = () => { // Access the DOM node directly and focus the input element this.inputRef.current.focus(); }; render() { return ( <div> <input ref={this.inputRef} type="text" /> <button onClick={this.handleFocus}>Focus Input</button> </div> ); } } export default MyComponent;
이 예에서는 useEffect 후크와 참조 덕분에 구성요소가 마운트될 때 입력에 자동으로 초점이 맞춰집니다.
ㄷ. 애니메이션 트리거 또는 타사 라이브러리와 통합
참조는 종종 타사 라이브러리와 상호 작용하거나 명령형 애니메이션을 트리거하는 데 사용됩니다. 예를 들어 참조를 사용하여 맞춤 애니메이션을 제어하거나 jQuery와 같은 비React 라이브러리와 상호작용할 수 있습니다.
디. 양식 검증
Ref는 React 상태에 데이터를 저장하지 않고 양식 데이터를 수집하는 데에도 사용할 수 있으므로 실시간 업데이트가 필요하지 않은 양식에 대한 간단한 대안을 제공합니다.
4. 여러 요소에 대한 참조 관리
여러 요소로 작업할 때 객체나 배열에 참조를 저장하여 각 요소에 액세스할 수 있습니다.
여러 요소에 대한 참조의 예:
import React, { useRef } from 'react'; const MyComponent = () => { const inputRef = useRef(); const handleFocus = () => { // Access the DOM node directly and focus the input element inputRef.current.focus(); }; return ( <div> <input ref={inputRef} type="text" /> <button onClick={handleFocus}>Focus Input</button> </div> ); }; export default MyComponent;
이 예에서는 여러 입력 요소가 참조 배열을 사용하여 관리되고 버튼을 사용하여 두 번째 입력에 초점을 맞춥니다.
5. 참조 대 상태
ref가 DOM과 상호작용하는 방법을 제공하는 반면, React의 state는 UI 렌더링에 영향을 미치는 데이터를 관리하는 데 사용됩니다. 각 항목을 언제 사용해야 하는지 이해하는 것이 중요합니다.
- 상태는 동적 렌더링에 사용됩니다. 데이터가 변경되어 UI 렌더링 방법에 영향을 미치는 경우 상태를 사용하세요.
- 참조는 명령형 작업에 사용됩니다. DOM 요소와 직접 상호작용해야 하는 경우(예: 초점 맞추기, 측정 또는 애니메이션 트리거) 참조를 사용하세요.
6. 결론
Ref의 Ref는 DOM 요소에 직접 액세스하고 조작할 수 있는 강력한 기능입니다. UI와 상호작용하는 필수적인 방법을 제공하여 입력 필드에 초점 맞추기, 애니메이션 트리거하기, 타사 라이브러리와의 통합과 같은 작업을 가능하게 합니다.
React는 상태 및 props를 사용한 선언적 접근 방식을 권장하는 반면, ref는 DOM과 보다 직접적인 상호 작용을 수행해야 할 때 필수적인 도구 역할을 합니다.
위 내용은 React의 Ref와 DOM 이해: DOM 요소 액세스 및 조작의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

핫 AI 도구

Undresser.AI Undress
사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover
사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool
무료로 이미지를 벗다

Clothoff.io
AI 옷 제거제

AI Hentai Generator
AI Hentai를 무료로 생성하십시오.

인기 기사

뜨거운 도구

메모장++7.3.1
사용하기 쉬운 무료 코드 편집기

SublimeText3 중국어 버전
중국어 버전, 사용하기 매우 쉽습니다.

스튜디오 13.0.1 보내기
강력한 PHP 통합 개발 환경

드림위버 CS6
시각적 웹 개발 도구

SublimeText3 Mac 버전
신 수준의 코드 편집 소프트웨어(SublimeText3)

뜨거운 주제











기사는 JavaScript 라이브러리 작성, 게시 및 유지 관리, 계획, 개발, 테스트, 문서 및 홍보 전략에 중점을 둡니다.

이 기사는 브라우저에서 JavaScript 성능을 최적화하기위한 전략에 대해 설명하고 실행 시간을 줄이고 페이지로드 속도에 미치는 영향을 최소화하는 데 중점을 둡니다.

프론트 엔드 개발시 프론트 엔드 열지대 티켓 인쇄를위한 자주 묻는 질문과 솔루션, 티켓 인쇄는 일반적인 요구 사항입니다. 그러나 많은 개발자들이 구현하고 있습니다 ...

이 기사는 브라우저 개발자 도구를 사용하여 효과적인 JavaScript 디버깅, 중단 점 설정, 콘솔 사용 및 성능 분석에 중점을 둡니다.

기술 및 산업 요구에 따라 Python 및 JavaScript 개발자에 대한 절대 급여는 없습니다. 1. 파이썬은 데이터 과학 및 기계 학습에서 더 많은 비용을 지불 할 수 있습니다. 2. JavaScript는 프론트 엔드 및 풀 스택 개발에 큰 수요가 있으며 급여도 상당합니다. 3. 영향 요인에는 경험, 지리적 위치, 회사 규모 및 특정 기술이 포함됩니다.

이 기사는 소스 맵을 사용하여 원래 코드에 다시 매핑하여 미니어링 된 JavaScript를 디버그하는 방법을 설명합니다. 소스 맵 활성화, 브레이크 포인트 설정 및 Chrome Devtools 및 Webpack과 같은 도구 사용에 대해 설명합니다.

이 튜토리얼은 Chart.js를 사용하여 파이, 링 및 버블 차트를 만드는 방법을 설명합니다. 이전에는 차트 유형의 차트 유형을 배웠습니다. JS : 라인 차트 및 막대 차트 (자습서 2)와 레이더 차트 및 극지 지역 차트 (자습서 3)를 배웠습니다. 파이 및 링 차트를 만듭니다 파이 차트와 링 차트는 다른 부분으로 나뉘어 진 전체의 비율을 보여주는 데 이상적입니다. 예를 들어, 파이 차트는 사파리에서 남성 사자, 여성 사자 및 젊은 사자의 비율 또는 선거에서 다른 후보자가받는 투표율을 보여주는 데 사용될 수 있습니다. 파이 차트는 단일 매개 변수 또는 데이터 세트를 비교하는 데만 적합합니다. 파이 차트의 팬 각도는 데이터 포인트의 숫자 크기에 의존하기 때문에 원형 차트는 값이 0 인 엔티티를 그릴 수 없습니다. 이것은 비율이 0 인 모든 엔티티를 의미합니다

Console.log 출력의 차이의 근본 원인에 대한 심층적 인 논의. 이 기사에서는 Console.log 함수의 출력 결과의 차이점을 코드에서 분석하고 그에 따른 이유를 설명합니다. � ...
