>웹 프론트엔드 >JS 튜토리얼 >값을 반환하지 않고 약속을 연결하면 정의되지 않은 값이 발생하는 이유는 무엇입니까?

값을 반환하지 않고 약속을 연결하면 정의되지 않은 값이 발생하는 이유는 무엇입니까?

Mary-Kate Olsen
Mary-Kate Olsen원래의
2024-10-19 22:13:29714검색

Why Do Promises Chain Without Returning a Value Result in Undefined Values?

연결된 Promise의 정의되지 않은 값 이해

JavaScript에서 Promise는 비동기 작업에 사용됩니다. 계산 결과를 처리하고 성공 및 실패와 같은 시나리오를 처리하는 방법을 제공합니다. 그러나 Promise를 체이닝할 때 예상치 못한 undefed 값이 발생하는 경우가 있습니다.

근본 원인: 값을 반환하지 않고 체이닝

Promise는 .then() 메서드를 사용하여 체이닝됩니다. Promise가 해결되거나 거부되면 .then() 메서드는 새 Promise 객체를 반환합니다. 그러나 .then() 메서드에서 명시적으로 값이 반환되지 않거나 Promise가 반환되는 경우 새 Promise 객체는 정의되지 않은 기본값으로 해결됩니다.

예:

<code class="javascript">doStuff(9)
  .then(function(result) {
    // No value or Promise returned
    if (result > 100) {
      console.log(result + " is greater than 100");
    } else {
      console.log(result + " is not greater than 100");
    }
  })
  .then(function(data) {
    console.log(data); // Output: undefined
  });</code>

이 예에서 첫 번째 .then() 메서드는 값을 반환하지 않습니다. 결과적으로, 두 번째 .then() 메서드는 인수로 unundefined를 받은 다음 콘솔에 인쇄됩니다.

해결책: 값 또는 약속 반환

연결된 Promise에서 정의되지 않은 값을 방지하려면 값 또는 값을 반환하는 Promise가 .then() 메서드에서 명시적으로 반환되어야 합니다.

예:

<code class="javascript">doStuff(9)
  .then(function(result) {
    if (result > 100) {
      console.log(result + " is greater than 100");
    } else {
      console.log(result + " is not greater than 100");
    }
    // Return the result to avoid undefined at the next .then()
    return result;
  })
  .then(function(data) {
    console.log("data is: " + data); // Output: "data is: 90"
  });</code>

결과를 반환함으로써 두 번째 .then() 메서드는 정의되지 않은 대신 실제 결과 값을 받습니다.

위 내용은 값을 반환하지 않고 약속을 연결하면 정의되지 않은 값이 발생하는 이유는 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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