"일꾼이 일을 잘하려면 먼저 도구를 갈고 닦아야 한다." - 공자, 『논어』.
첫 장 > 프로그램 작성 > .then(function(a){ return a; }) 는 Promise에 대한 No-Op입니까?

.then(function(a){ return a; }) 는 Promise에 대한 No-Op입니까?

2024년 11월 16일에 게시됨
검색:147

Is .then(function(a){ return a; }) a No-Op for Promises?

.then(function(a){ return a; })는 Promise에 대한 No-Op입니까?

Promise의 영역에서 , .then(function(a){ return a; }) 이 무연산인지에 대한 질문이 발생했습니다. 이 흥미로운 쿼리를 살펴보겠습니다.

예, 일반적으로 아무런 작업도 수행하지 않습니다.

문제의 코드는 다음에서 이전 Promise의 반환 값을 받습니다. .then()에 전달된 함수를 통해 체인을 연결합니다. 그러나 해당 함수가 단순히 입력 a를 반환하는 경우 Promise 결과의 처리 또는 변환을 효과적으로 우회합니다. 이로 인해 Promise 파이프라인에서 무해하지만 불필요한 추가 단계가 됩니다.

왜 그렇게 작성되었나요?

오타이거나 이전의 오해에서 비롯된 유물일 가능성이 높습니다. 약속. Promise가 도입되었을 때 일부 개발자는 .then()이 체인을 계속하려면 Promise를 반환해야 한다고 잘못 믿었습니다. 결과적으로 그들은 반환된 값이 입력과 동일하더라도 항상 약속으로 유지되도록 하기 위해 불필요한 .then() 호출을 추가했습니다.

.then() 반환과 .then() 반환 간의 차이점 생략

의미적으로는 동일하지만 .then()을 반환하는 것과 생략하는 것 사이에는 미묘한 차이가 있습니다. it:

  • 새 약속 인스턴스: .then() 은 새 약속 인스턴스를 생성하고 생략하면 원본을 재사용합니다. 그러나 이러한 구별은 일반적으로 관련이 없습니다.
  • Thenable-ness 확인: .then()을 사용하면 반환된 값을 확인하여 Promise인지 아닌지를 결정합니다. .then()을 생략하면 이 검사를 건너뜁니다.

특수 케이스

드물게 .then(function(a){ return a; })가 발생할 수 있습니다. 비정상적인 동작이 있습니다:

  • 반환된 값이 이행 후 갑자기 약속이 되면 .then()이 대기합니다. it.
  • 공유 회피에 유용할 수 있는 고유한 약속 개체를 반환합니다. 그러나 이는 틈새 사용 사례입니다.

결론

일반적으로 .then(function(a){ return a; })은 아니요입니다. -op는 약속 체인에 어떤 가치도 추가하지 않습니다. 공유된 약속을 피하거나 모호한 thenable 관련 동작을 처리하는 등 사용해야 할 강력한 이유가 없는 한 생략해야 합니다.

최신 튜토리얼 더>

부인 성명: 제공된 모든 리소스는 부분적으로 인터넷에서 가져온 것입니다. 귀하의 저작권이나 기타 권리 및 이익이 침해된 경우 자세한 이유를 설명하고 저작권 또는 권리 및 이익에 대한 증거를 제공한 후 이메일([email protected])로 보내주십시오. 최대한 빨리 처리해 드리겠습니다.

Copyright© 2022 湘ICP备2022001581号-3