示例:javascript
<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8" />
<title>vue 鉤子函數 使用async await</title>
</head>
<body>
<div id="app">
<div v-for="item in list"> {{ item }} </div>
</div>
<script src="https://cdn.bootcss.com/vue/2.5.17/vue.min.js"></script>
<script type="text/javascript">
var app = new Vue({ el: '#app', data: { list: [1, 2, 3] }, async created(){ // 最早輸出3
console.log(3) await setTimeout(()=>{ // 1輸出的時間依賴於 定時間隔
console.log(1) },100) // 5的輸出順序也不是在1後面
console.log(5) }, async mounted(){ // 其次輸出4
console.log(4) await setTimeout(()=>{ // 2輸出的時間依賴於 定時間隔
console.log(2) },100) // 6的輸出順序也不是在2後面
console.log(6) } }) </script>
</body>
</html>
經過設置created和mounted中定時時間不一樣,查看控制檯輸出順序。css
徹底亂套!html
只能保證最早輸出3 其次輸出4。vue
await後的 5 和 6 也不是在await後輸出。java
結論是:全部的鉤子函數都只是在指定時間執行而已,框架並不關心它們執行的結果,因此你要作的是將async和await放到真正有異步的methods的方法中。app
更新!上面代碼啪啪打臉!框架
await後不能接收非Promise對象。異步
請參考:https://www.jianshu.com/p/2afb088abd08async
await setTimeout(...) 或者 await exec(...) 是不行滴,await 不是什麼都等,它等待的只是Promise,你若是沒有給他返回個Promise,那它仍是會繼續向下執行。函數
因此 await 等待的不是全部的異步操做,等待的只是Promise。
因此await 擋不住啊!