js 的 async await 说到底还是伪异步吗?

2018-04-02 16:08:35 +08:00
 LeungJZ

实践基于 vue

如下图,左边是 component 的 mounted 函数,右边是 mixin 的 mounted 函数。

在 vue 中,mixin 的 mounted 会比 component 的先执行。

所以我当时就想,在 mixin 中先获取数据,再交由 component 处理,因为该 mixin 在两个组件中都用上了。

可是,事与愿违,mixin 中 await 后的函数还是会等到所有的 mounted 执行完成后才会执行的。

那么请问一下,我该如何去调整?

2946 次点击
所在节点    问与答
11 条回复
wwqgtxx
2018-04-02 16:11:01 +08:00
异步执行也没人说就一定是并发执行吧
LeungJZ
2018-04-02 16:15:53 +08:00
@wwqgtxx
以为是 await 后的,会等返回结果再执行,原来只限于本函数。
maichael
2018-04-02 16:27:38 +08:00
如果 await 后所有代码都要等返回回来再执行,那叫阻塞。

阻塞和非阻塞,和你是异步还是不是异步一点关系都没有。
LeungJZ
2018-04-02 16:35:29 +08:00
@maichael
好吧,表达错了。
wwqgtxx
2018-04-02 17:03:37 +08:00
@LeungJZ 本质上 await 是用 switch 实现的,你可以用 babel 转码成 es5 看看就知道了,所以他的作用域局限于 async 函数内
Yuiham
2018-04-02 17:03:52 +08:00
mixins 和组件提供的生命周期钩子会在组件初始化的时候合并成数组。但是生命周期钩子的调用是同步的顺序的,调用完第一个 mounted 后接着调用第二个。你的 mixins 提供的 mounted 里的请求响应至少得到下一轮事件循环了
LeungJZ
2018-04-02 17:05:09 +08:00
@Yuiham
但是事件处理弄到 setTimeout 还是不行。
Yuiham
2018-04-02 17:19:29 +08:00
@LeungJZ 你在组件的 created 中用 $once 监听一个事件 a,注册 callback。接着等 mixins 的 mounted 拿到响应数据,带上数据 emit 这个事件 a。这样可以干掉多余的本地状态和生命周期钩子。
AJian
2018-04-02 17:21:01 +08:00
只是对语法糖而已
crs0910
2018-04-02 17:50:20 +08:00
mixin 里写成 method,然后 component 的 amounted 钩子里面 await 调用
LeungJZ
2018-04-02 17:52:32 +08:00
@crs0910
这是我现在唯一能想到的解决办法。


@Yuiham
这个方法好像不错。我试试,谢谢了。

这是一个专为移动设备优化的页面(即为了让你能够在 Google 搜索结果里秒开这个页面),如果你希望参与 V2EX 社区的讨论,你可以继续到 V2EX 上打开本讨论主题的完整版本。

https://www.v2ex.com/t/443587

V2EX 是创意工作者们的社区,是一个分享自己正在做的有趣事物、交流想法,可以遇见新朋友甚至新机会的地方。

V2EX is a community of developers, designers and creative people.

© 2021 V2EX