>웹 프론트엔드 >View.js >Vue의 TypeError: 정의되지 않은 'XXX' 속성을 읽을 수 없습니다. 해결 방법은 무엇입니까?

Vue의 TypeError: 정의되지 않은 'XXX' 속성을 읽을 수 없습니다. 해결 방법은 무엇입니까?

王林
王林원래의
2023-11-25 12:58:441284검색

Vue中的TypeError: Cannot read property 'XXX' of undefined,解决方法有哪些?

Vue는 널리 사용되는 프런트 엔드 프레임워크로서 웹 애플리케이션을 개발하는 데 자주 사용됩니다. 그런데 Vue를 사용하여 개발하는 과정에서 "TypeError: Cannot read property 'XXX' of undefine"과 같은 오류가 발생하는 경우가 있는데 어떻게 해결해야 할까요? 이 문서에서는 이 오류를 해결하는 방법을 자세히 설명합니다.

먼저 "TypeError: 정의되지 않은 'XXX' 속성을 읽을 수 없습니다." 오류가 무엇인지 이해해 보겠습니다. 이 오류는 일반적으로 코드에서 정의되지 않은 속성이나 메서드에 액세스할 때 발생합니다. 예를 들어 Vue 구성 요소에서 아래와 같이 구성 요소에서 정의되지 않은 데이터 속성에 액세스하는 상황이 발생할 수 있습니다.

export default {
  data() {
    return {
      message: 'Hello, World!'
    }
  },
  methods: {
    showMessage() {
      console.log(this.message.toUpperCase()); // TypeError: Cannot read property 'toUpperCase' of undefined
    }
  }
}

위 코드의 showMessage 메서드에서 존재하지 않는 데이터 속성에 액세스하려고 시도합니다. message.toUpperCase()이므로 "TypeError: 정의되지 않은 'toUpperCase' 속성을 읽을 수 없습니다." 오류가 발생합니다.

다음으로 이 오류를 해결하는 방법을 소개하겠습니다.

1. 객체가 정의되어 있는지 확인하세요

먼저 코드에서 접근한 객체가 정의되어 있는지 확인하세요. 그렇지 않으면 오류가 발생합니다. 따라서 객체가 정의되었는지 확인하려면 if 문이나 삼항 연산자를 사용해야 합니다.

export default {
  data() {
    return {
      message: 'Hello, World!'
    }
  },
  methods: {
    showMessage() {
      if (this.message) {
        console.log(this.message.toUpperCase());
      }
    }
  }
}

위 코드에서는 if 문을 사용하여 this.message가 정의되었는지 확인합니다. this.message가 정의된 경우에만 console.log 문이 실행됩니다.

2. 선택적 체인 연산자(?.)를 사용하세요.

Vue3.0 이상에서는 정의되지 않은 속성이나 메서드에 액세스하는 것을 방지하기 위해 선택적 체인 연산자(?.)를 사용할 수 있습니다. 이 연산자는 왼쪽 표현식이 정의되지 않았거나 null인 경우 오른쪽 표현식이 실행되지 않음을 의미합니다.

export default {
  data() {
    return {
      message: 'Hello, World!'
    }
  },
  methods: {
    showMessage() {
      console.log(this.message?.toUpperCase()); // 如果this.message未定义,则不会执行toUpperCase()方法
    }
  }
}

위 코드에서는 선택적 체인 연산자(?.)를 사용하여 this.message 속성에 액세스합니다. this.message가 정의되지 않은 경우 toUpperCase() 메서드가 실행되지 않으므로 TypeError가 발생하지 않습니다. .

3. 기본값 사용 ​​

정의되지 않은 속성이나 메서드에 액세스할 때 TypeError 오류가 발생하지 않도록 기본값을 사용할 수도 있습니다.

export default {
  data() {
    return {
      message: 'Hello, World!'
    }
  },
  methods: {
    showMessage() {
      console.log((this.message || '').toUpperCase()); // 如果this.message未定义,则返回空字符串
    }
  }
}

위 코드에서는 TypeError 오류가 발생하지 않도록 OR 연산자(||)를 사용하여 this.message의 기본값(빈 문자열)을 설정했습니다.

요약하자면, "TypeError: 정의되지 않은 'XXX' 속성을 읽을 수 없습니다." 오류가 발생하면 위의 세 가지 방법을 사용하여 오류를 해결할 수 있습니다. Vue 코드를 작성할 때 이러한 오류가 발생하지 않도록 객체가 정의되어 있는지 주의 깊게 확인하세요.

위 내용은 Vue의 TypeError: 정의되지 않은 'XXX' 속성을 읽을 수 없습니다. 해결 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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