vue 구성 요소에 정의된 구성 요소에 액세스할 수 없습니다.
Vue 개발에서는 일반적으로 재사용 가능한 일부 기능을 캡슐화하기 위해 구성 요소를 사용합니다. 때로는 구성 요소 내에 정의된 구성 요소에 액세스할 수 없는 상황이 발생할 수 있으며, 이로 인해 종종 문제가 발생합니다. 이 문서에서는 Vue 구성 요소에 정의된 구성 요소에 액세스할 수 없는 이유와 이 문제를 해결하는 방법을 자세히 설명합니다.
- Reason
Vue 컴포넌트의 데이터, 메소드, 라이프사이클 후크 등은 모두 컴포넌트 범위 내에 캡슐화되어 있으며, 컴포넌트 내에 정의된 컴포넌트도 마찬가지입니다. 따라서 컴포넌트 내부에 정의된 컴포넌트는 컴포넌트 외부에서 직접 접근할 수 없습니다.
예를 들어 아래 예에서는 상위 구성 요소와 하위 구성 요소를 정의하고 상위 구성 요소에 하위 구성 요소를 도입합니다.
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 |
|
그러나 하위 구성 요소 외부에서 하위 구성 요소에 직접 액세스하는 경우는 다음과 같습니다.
1 |
|
이때, 하위 구성요소에 접근할 수 없음을 나타내는 undefound가 출력됩니다. 하위 구성 요소는 상위 구성 요소 범위 내에서만 인식 및 액세스할 수 있고 하위 구성 요소는 전역 범위에 노출되지 않기 때문입니다.
- 해결책
그렇다면 상위 구성 요소에 정의된 구성 요소를 구성 요소 외부에서 액세스할 수 있게 만드는 방법은 무엇일까요? 다음은 두 가지 가능한 방법입니다:
2.1 $refs 사용
Vue 구성 요소에는 구성 요소 또는 DOM 요소에 액세스하는 데 사용할 수 있는 고유 식별자 $refs가 있습니다. 따라서 상위 구성 요소의 $refs를 통해 하위 구성 요소를 가져와 하위 구성 요소 내부의 구성 요소에 액세스할 수 있습니다.
위 예제 코드를 수정하고, 상위 구성 요소에 버튼을 추가하고, 버튼 클릭 이벤트의 $refs를 통해 하위 구성 요소에 액세스합니다.
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 |
|
위 코드에서는 하위 구성 요소에 ref 속성을 추가합니다. 상위 구성 요소의 $refs 속성에 마운트됩니다. 그런 다음 상위 구성 요소의 click 이벤트에서 $refs.childComponent를 통해 하위 구성 요소 객체에 액세스하고 $children 속성을 통해 하위 구성 요소 객체 내부의 구성 요소를 얻습니다.
2.2 믹스인 사용
Vue는 $refs 외에도 믹스인(mix-in) 개념도 제공합니다. 믹스인은 구성 요소에 대한 몇 가지 공통 논리 또는 코드 조각을 제공하여 코드 재사용성을 향상시킬 수 있습니다. 따라서 믹스인을 통해 하위 구성요소 내부의 구성요소를 상위 구성요소에 노출할 수 있습니다.
위 예제 코드를 수정하고, 하위 구성 요소에 믹스인을 정의하고, 하위 구성 요소 내부의 구성 요소를 믹스인의 전역 범위에 노출합니다.
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 |
|
위 코드에서는 다음을 사용하여 하위 구성 요소에 믹스인을 정의합니다. 하위 구성 요소 내부의 구성 요소를 전역 범위로 확장합니다. 구체적으로, SubComponent 객체를 상수로 정의하고 생성된 믹스인 후크에 있는 전역 범위의 $SubComponent 속성에 마운트합니다. 그런 다음 상위 구성 요소에서 window.$SubComponent를 통해 하위 구성 요소 내부의 구성 요소에 액세스할 수 있습니다.
- Summary
위는 Vue 컴포넌트에 정의된 접근 불가능한 컴포넌트 문제를 해결하기 위한 두 가지 방법으로, $refs와 mixin을 사용하는 것입니다. $refs는 상위 구성 요소의 하위 구성 요소 내부에 있는 구성 요소에 직접 액세스하는 데 적합하고, mixin은 하위 구성 요소 내부의 구성 요소를 전역 범위에 노출하는 데 적합합니다. 특정 요구 사항의 경우 실제 상황에 따라 적절한 솔루션을 선택할 수 있습니다.
위 내용은 vue 구성 요소에 정의된 구성 요소에 액세스할 수 없습니다.의 상세 내용입니다. 자세한 내용은 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)

뜨거운 주제











이 기사에서는 Data Fetching 및 기능 구성 요소의 DOM 조작과 같은 부작용을 관리하기위한 후크 인 React의 useEffect에 대해 설명합니다. 메모리 누출과 같은 문제를 방지하기 위해 사용법, 일반적인 부작용 및 정리를 설명합니다.

게으른로드는 필요할 때까지 컨텐츠로드를 지연시켜 초기로드 시간과 서버로드를 줄임으로써 웹 성능 및 사용자 경험을 향상시킵니다.

JavaScript의 고차 기능은 추상화, 공통 패턴 및 최적화 기술을 통해 코드 간접성, 재사용 성, 모듈성 및 성능을 향상시킵니다.

이 기사는 다중 연계 기능을 단일 연계 함수 시퀀스로 변환하는 기술 인 JavaScript의 카레에 대해 논의합니다. Currying의 구현, 부분 응용 프로그램 및 실제 용도와 같은 혜택, 코드 읽기 향상을 탐색합니다.

이 기사는 가상 Dom 트리를 비교하여 DOM을 효율적으로 업데이트하는 React의 조정 알고리즘을 설명합니다. 성능 이점, 최적화 기술 및 사용자 경험에 미치는 영향에 대해 설명합니다. 문자 수 : 159

기사에서는 extentdefault () 메서드를 사용하여 이벤트 처리기의 기본 동작 방지, 향상된 사용자 경험과 같은 이점 및 접근성 문제와 같은 잠재적 문제에 대해 논의합니다.

이 기사는 REACT의 USECONTEXT를 설명하며, 이는 PROP 시추를 피함으로써 상태 관리를 단순화합니다. 중앙 집중식 상태 및 성능 개선과 같은 렌더링을 통해 성능 향상과 같은 이점에 대해 논의합니다.

이 기사는 예측 가능성, 성능 및 사용 사례와 같은 측면에 중점을 둔 React의 제어 및 통제되지 않은 구성 요소의 장단점에 대해 설명합니다. 그것은 그들 사이에서 선택할 때 고려해야 할 요소에 대해 조언합니다.
