Promise里面的waitDate方法为什么打印不出来


function fun(){
    console.log('fun');
}
new Promise((resolve,reject)=>{
    resolve('888')
    fun()
    waitDate()
}).then(
    value => {console.log('then');setTimeout(console.log(value),500)},
    error => {console.log(error);}
)
function waitDate(){
    setTimeout(printName,1000)
}

function printName(){
    console.log('name');
}

img

该回答通过自己思路及引用到GPTᴼᴾᴱᴺᴬᴵ搜索,得到内容具体如下:

在 Promise 对象的构造函数中,resolve('888') 会立即执行,因此 fun()waitDate() 也会立即执行。由于 waitDate() 中使用了 setTimeout() 方法,因此 waitDate() 函数本身会立即返回,而不会等待 setTimeout() 方法中的定时器到期后再执行。

then() 方法中,value => {console.log('then');setTimeout(console.log(value),500)} 这一行代码中,setTimeout(console.log(value),500) 会立即执行,而不会等待定时器到期。这是因为 setTimeout() 方法的第一个参数是一个函数,而 console.log(value) 并不是一个函数,它会立即执行并将返回值传递给 setTimeout() 方法。

因此,你需要将要执行的函数作为 setTimeout() 方法的第一个参数,而不是将其作为 console.log() 函数的参数。修改后的代码如下:

function fun(){
    console.log('fun');
}

new Promise((resolve, reject) => {
    resolve('888');
    fun();
    waitDate();
}).then(
    value => {
        console.log('then');
        setTimeout(() => {
            console.log(value);
        }, 500);
    },
    error => {
        console.log(error);
    }
);

function waitDate(){
    setTimeout(printName, 1000);
}

function printName(){
    console.log('name');
}

在上面的代码中,我们将要执行的函数console.log(value) 封装在一个匿名函数中,并将该函数作为 setTimeout() 方法的第一个参数。这样,console.log(value) 就会在定时器到期后执行,而不是立即执行。


如果以上回答对您有所帮助,点击一下采纳该答案~谢谢

settime 第一个参数你传的不是一个 function

function fun(){
  console.log('fun');
}
new Promise((resolve,reject)=>{
  resolve('888')
  fun()
  waitDate()
}).then(
  value => {console.log('then');setTimeout(()=>console.log(value),500)},
  error => {console.log(error);}
)
function waitDate(){
  setTimeout(printName,1000)
}

function printName(){
  console.log('name');
}