>웹 프론트엔드 >JS 튜토리얼 >Vue.js 수명 주기 후크 및 계산된 속성에서 \'this\'가 정의되지 않은 이유는 무엇입니까?

Vue.js 수명 주기 후크 및 계산된 속성에서 \'this\'가 정의되지 않은 이유는 무엇입니까?

DDD
DDD원래의
2024-11-28 04:58:10806검색

Why Does

VueJS: "this"는 수명 주기 후크 및 계산된 속성에 정의되지 않았습니다.

Vue.js에서는 "this"에 액세스하는 상황이 발생할 수 있습니다. 수명 주기 후크 또는 계산된 속성 내의 " 키워드는 "정의되지 않음"을 반환합니다. 화살표 함수를 사용할 때 발생합니다.

원인:

화살표 함수() => {} "this" 키워드를 Vue 인스턴스 외부의 컨텍스트에 바인딩합니다. 이는 화살표 함수 내의 "this"가 Vue 인스턴스 자체가 아닌 상위 범위를 참조한다는 것을 의미합니다.

예제 1:

mounted: () => {
  console.log(this); // logs "undefined"
}

이 예에서, "마운트된" 후크에 사용된 화살표 기능은 "this"를 Vue에 바인딩하지 않습니다. 인스턴스.

예 2:

computed: {
  foo: () => { 
    return this.bar + 1; 
  }
}

여기서 계산된 속성은 화살표 함수를 사용합니다. 이로 인해 "this.bar"에 대한 참조가 정의되지 않음으로 평가됩니다. , "다음의 속성 'bar'를 읽을 수 없습니다."라는 오류가 발생합니다. 정의되지 않음."

해결책:

이 문제를 해결하고 "this"에 대한 올바른 참조에 액세스하려면 일반 함수나 ES5 단축어를 사용하세요.

레귤러 기능:

mounted: function () {
  console.log(this);
}

ES5 약어:

mounted() {
  console.log(this);
}

이러한 접근 방식을 사용하면 "this"가 수명 주기 내의 Vue 인스턴스를 참조하는지 확인할 수 있습니다. 후크 및 계산된 속성.

위 내용은 Vue.js 수명 주기 후크 및 계산된 속성에서 \'this\'가 정의되지 않은 이유는 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.