|
|
1
3
我想我之所以回答这个问题,主要是因为JavaScript中的异步曾经把我搞糊涂了,突然间,它突然断了,所以我希望这个类比可以帮助您实现这一点。 您有一个异步事件。这可以是任何事情,从服务器获取一些东西,在浏览器中做一些需要时间的事情,训练机器学习模型!!),执行使用settimeout等的函数或方法。 Javascript的优点和它在浏览器中如此出色的一个关键原因是它使用了运行在上面的处理器线程,以一种非常巧妙的方式阻止线程被需要时间的进程阻塞(如上面提到的进程)。 许多其他语言,例如Ruby在多个线程上运行。可以使用服务工作者在javascript中的多个线程上运行进程,但这超出了这个答案的范围! JS事件循环的异步特性允许线程在等待进程完成时“关闭”并执行其他操作。 从编程的角度来看,这一问题在于,如果代码中的某个依赖于阻塞事件的结果的内容在尝试使用其结果之前不等待该事件完成,那么它可能由于该事件而导致“未定义”。把这段代码记在下面
当代码到达控制台日志时,设置超时尚未完成。由于setTimeout仅在scopedvariable完成时设置它,因此当我们记录它时,该变量是未定义的。 但是如果我们将超时包装在一个承诺中,我们可以等待它的resolve回调(promise的第一个参数),代码将“暂停”直到promise到达resolve回调,然后继续。 当我们等待promise并且setTimeout完成时,resolve函数设置变量,以便当我们控制台记录它时,它保存来自promise的值。
你可以用“等待”和“交换”。 例如,我们可以去:
代码将再次在处暂停。然后在AsyncEvent承诺解决后继续。 实际上,如果我们使用。那么我们不需要将它包含在异步函数中,这样我们就可以像这样重写它。
关于.then,最棒的是,附带的.catch允许您捕获异步事件引发的任何错误(例如,如果在发生错误时从服务器检索某些内容)。对于async wait,您需要在try catch中包装潜在的危险函数。 为了使用await,您需要在一个异步函数(因此上面的异步容器函数)内。这不是必需的。那么,但是。那么和。锁链会使代码混乱。 希望这有帮助! |
|
|
2
1
这个
使用
使用
有关关系之间的更多信息,请参见 How to translate Promise code to async await |
|
|
code-geek · Jquery根据单选按钮选择隐藏或显示文本字段 11 月前 |
|
|
Niobos · 如何/是否有方法使通用算法函数同时与同步和异步函数一起工作? 11 月前 |
|
|
Alex · 在轻量级中同时解构和不解构变量 11 月前 |
|
|
Ângelo Rigo · ReactJS映射:如何迭代[关闭] 11 月前 |
|
|
bairog · 从按属性筛选的对象数组字典中创建值数组 11 月前 |
|
|
lokiuucx · JS对象属性返回未定义,尽管对象属性应该有值 11 月前 |