React에서 refs는 DOM 요소에 직접 액세스하고 상호 작용하는 데 사용됩니다. React는 일반적으로 상태와 소품을 통해 선언적인 방식으로 DOM을 관리하지만 애니메이션, 양식 필드 포커스 또는 요소 크기 측정과 같이 DOM과 직접 상호 작용해야 하는 경우가 있습니다. 이러한 경우 참조는 기본 DOM 노드에 액세스하는 방법을 제공합니다.
ref(reference의 약자)는 DOM 요소나 React 구성 요소 인스턴스를 참조할 수 있는 객체입니다. Ref는 클래스 컴포넌트에서 React.createRef()를 사용하거나 함수 컴포넌트에서 useRef()를 사용하여 생성할 수 있습니다. Refs는 일반적으로 다음 용도로 사용됩니다.
클래스 컴포넌트에서는 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;
이 예에서는:
함수 구성 요소에서는 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;
이 예에서는:
Ref는 일반적으로 DOM 요소에 직접 액세스하고 조작하는 데 사용됩니다. 예를 들어 텍스트 입력에 초점을 맞추거나 요소의 크기를 측정하는 것은 참조를 사용하여 쉽게 수행할 수 있습니다.
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 상태에 데이터를 저장하지 않고 양식 데이터를 수집하는 데에도 사용할 수 있으므로 실시간 업데이트가 필요하지 않은 양식에 대한 간단한 대안을 제공합니다.
여러 요소로 작업할 때 객체나 배열에 참조를 저장하여 각 요소에 액세스할 수 있습니다.
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;
이 예에서는 여러 입력 요소가 참조 배열을 사용하여 관리되고 버튼을 사용하여 두 번째 입력에 초점을 맞춥니다.
ref가 DOM과 상호작용하는 방법을 제공하는 반면, React의 state는 UI 렌더링에 영향을 미치는 데이터를 관리하는 데 사용됩니다. 각 항목을 언제 사용해야 하는지 이해하는 것이 중요합니다.
Ref의 Ref는 DOM 요소에 직접 액세스하고 조작할 수 있는 강력한 기능입니다. UI와 상호작용하는 필수적인 방법을 제공하여 입력 필드에 초점 맞추기, 애니메이션 트리거하기, 타사 라이브러리와의 통합과 같은 작업을 가능하게 합니다.
React는 상태 및 props를 사용한 선언적 접근 방식을 권장하는 반면, ref는 DOM과 보다 직접적인 상호 작용을 수행해야 할 때 필수적인 도구 역할을 합니다.
위 내용은 React의 Ref와 DOM 이해: DOM 요소 액세스 및 조작의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!