vue 단일 파일 구성 요소에서 $refs를 가져올 수 없는 문제
코드
header.html
<body>
<div id="popup-wrap">
<popup ref="popup"></popup>
</div>
</body>
header.js
import popup from '../../components/popup/popup.vue'
import './header.scss'
let header_vue;
$(function () {
header_vue = new Vue({
el: '#popup-wrap',
data: {
},
mounted: {
// {popup: VueComponent}
console.log(this.$refs);
}
components: {popup},
methods: {
pop_data: function () {
// {}
console.log(this.$refs);
}
}
});
});
export {header_vue}
other.js
import {header_vue} from "../header/header";
$(function () {
header_vue.pop_data()
});
popup.vue는 일반적인 탄창 구성 요소입니다.나는 헤더에 있다.js에 이 구성 요소를 도입하고 header_vue는 popup 구성 요소를 사용하고 other에 있습니다.js에 header_ 도입vue pop_ 사용 시도데이터 함수, 이 함수는 헤더만 출력_vue의 $refs, 테스트를 통해 이 함수는 빈 대상으로 출력되지만mounted 갈고리는 정상적으로 출력됩니다.왜 mounted가 정상적으로 출력되고 함수 호출이 비어 있는지 궁금해요. Vue도 마운트가 끝났어요.
resolve
화가 치밀어 오르는 debug 후, 헤더에서.js의 $(function ()에 console가 추가되었습니다.log('ok'), 결국 브라우저가 두 ok를 출력했습니다.짧은 시간 동안 대뇌의 고속 운행 후에 나는 문제의 소재를 발견했다.
웹팩은 헤더를 두 번 포장했다.js!
그래서 해결책은 헤더를_vue = new Vue () 를 윈도우로 변경합니다.header_vue = new Vue().다른 데 그냥 쓰면 돼.
뒷말
현재 구체적인 버그의 발생 원인을 파악하지 못했고, 정상적으로 웹팩을 사용하여 여러 차례 같은 export를 도입했지만 이 문제가 발생한 적이 없다.하지만 분명히 내가 못 배웠을 거야. 큰 소가 알면 해답을 해 봐.
이 vue 단일 파일 구성 요소에서 $refs를 얻을 수 없는 문제에 대한 이 글을 소개합니다. 더 많은 관련 vue 단일 파일에서 $refs 내용을 얻을 수 없습니다. 이전의 글을 검색하거나 아래의 관련 글을 계속 보십시오. 앞으로 많은 응원 부탁드립니다!
이 내용에 흥미가 있습니까?
현재 기사가 여러분의 문제를 해결하지 못하는 경우 AI 엔진은 머신러닝 분석(스마트 모델이 방금 만들어져 부정확한 경우가 있을 수 있음)을 통해 가장 유사한 기사를 추천합니다:
Fastapi websocket 및 vue 3(Composition API)1부: FastAPI virtualenv 만들기(선택 사항) FastAPI 및 필요한 모든 것을 다음과 같이 설치하십시오. 생성main.py 파일 및 실행 - 브라우저에서 이 링크 열기http://127.0.0.1:...
텍스트를 자유롭게 공유하거나 복사할 수 있습니다.하지만 이 문서의 URL은 참조 URL로 남겨 두십시오.
CC BY-SA 2.5, CC BY-SA 3.0 및 CC BY-SA 4.0에 따라 라이센스가 부여됩니다.