函数返回 Promise{ <pending> } 在 JavaScript

问题描述

如果我将函数返回的 Promise 值存储在一个变量中,然后打印它,那么它会显示 Promise { pending }。 为什么 ?因为直到3秒承诺肯定会解决

let move = false;
function my() {
return new Promise(
    (resolve,reject) => {
        if (move === true)
            return resolve("resolved")
        else
            return reject(new Error("Rejected"));
    })
}

let obj = my().then((result) => {
    console.log("result",result);
})
.catch((err)=>{
    console.log("my error");
});

//it prints promise{ <pending> }
setTimeout(()=>{
    console.log("time",obj)},3000
) 

解决方法

promise 应该包装 setTimeout 函数并在 3 秒结束后解析。

let move = false;

function my() {
  return new Promise((resolve,reject) => {
    setTimeout(() => {
      if (move) {
        resolve('resolved');
      } else {
        reject(new Error('Rejected'));
      }
    },3000);
  });
}

my()
  .then(res => {
    console.log(res);
  })
  .catch(err => {
    console.log(err.message);
  });

相关问答

Selenium Web驱动程序和Java。元素在(x,y)点处不可单击。其...
Python-如何使用点“。” 访问字典成员?
Java 字符串是不可变的。到底是什么意思?
Java中的“ final”关键字如何工作?(我仍然可以修改对象。...
“loop:”在Java代码中。这是什么,为什么要编译?
java.lang.ClassNotFoundException:sun.jdbc.odbc.JdbcOdbc...