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');
}
Promise里面的waitDate方法为什么打印不出来
- 写回答
- 好问题 0 提建议
- 追加酬金
- 关注问题
- 邀请回答
-
2条回答 默认 最新
- Leodong. 2023-06-06 10:17关注
该回答通过自己思路及引用到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)
就会在定时器到期后执行,而不是立即执行。
如果以上回答对您有所帮助,点击一下采纳该答案~谢谢
本回答被题主选为最佳回答 , 对您是否有帮助呢?解决 无用评论 打赏 举报
悬赏问题
- ¥30 STM32 INMP441无法读取数据
- ¥100 求汇川机器人IRCB300控制器和示教器同版本升级固件文件升级包
- ¥15 用visualstudio2022创建vue项目后无法启动
- ¥15 x趋于0时tanx-sinx极限可以拆开算吗
- ¥500 把面具戴到人脸上,请大家贡献智慧
- ¥15 任意一个散点图自己下载其js脚本文件并做成独立的案例页面,不要作在线的,要离线状态。
- ¥15 各位 帮我看看如何写代码,打出来的图形要和如下图呈现的一样,急
- ¥30 c#打开word开启修订并实时显示批注
- ¥15 如何解决ldsc的这条报错/index error
- ¥15 VS2022+WDK驱动开发环境