VUE:使用async和await实现axios同步请求
程序员文章站
2023-12-22 08:44:34
...
vue使用async和await实现axios同步请求
一、axios异步请求出现的问题
handleClick(tab, e) {
this.$axios({
url: '/operatingsystem/student/selectStudentsByClno',
method: 'get',
params: {
clno: tab.props.name
}
}).then(res => {
this.StudentsByClno = res.obj
})
},
在页面中调用methods中handleClick函数中的axios请求时,因为.then
的特性,可能会出现后端返回的值还没赋值到StudentsByClno中时页面就对StudentsByClno中的数据进行渲染,从而导致报错或者后端数据来不及渲染到页面之上
二、解决办法:使用async 和await
async 和await 介绍
在ES7标准中新增了async
和await
关键字,作为处理异步请求的一种解决方案,实际上是一个语法糖,在ES6中已经可以用生成器语法完成同样的操作,但是async/await
的出现使得用这样的方式处理异步请求更加简单和明白。
使用async
和await
将会使axios从异步请求变为同步请求。
异步函数也就是意味着这个函数的执行不会阻塞后面代码的执行。
注意事项
- 只有在async方法里面才能使用await操作符;
- await操作符是针对Task对象的;
- 当方法A调用方法B,方法B方法体内又通过await调用方法C时,如果方法C内部有异步操作,则方法B会等待异步操作执行完,才往下执行;但方法A可以继续往下执行,不用再等待B方法执行完。
async handleClick(tab, e) {
await this.$axios({
url: '/operatingsystem/student/selectStudentsByClno',
method: 'get',
params: {
clno: tab.props.name
}
}).then(res => {
this.StudentsByClno = res.obj
})
},
三、突发问题
在使用async/await
时报了如下错误:
ERROR Failed to compile with 1 error 下午8:13:38
This dependency was not found:
* regenerator-runtime/runtime.js in ./node_modules/cache-loader/dist/cjs.js??ref--12-0!./node_modules/babel-loader/lib!./node_modules/cache-loader/dist/cjs.js??ref--0-0!.
/node_modules/vue-loader-v16/dist??ref--0-1!./src/views/Challenge.vue?vue&type=script&lang=js
To install it, you can run: npm install --save regenerator-runtime/runtime.js
让我运行:
npm install --save regenerator-runtime/runtime.js
可运行后又报错:
info: please complete authentication in your browser...Completed in 0ms
npm ERR! code 128
npm ERR! command failed
npm ERR! command git ls-remote ssh://[email protected]/regenerator-runtime/runtime.js.git
npm ERR! [email protected]: Permission denied (publickey).
npm ERR! fatal: Could not read from remote repository.
npm ERR!
npm ERR! Please make sure you have the correct access rights
npm ERR! and the repository exists.
npm ERR! A complete log of this run can be found in:
npm ERR! C:\Users\Ailjx\AppData\Local\npm-cache\_logs\2021-11-11T12_30_04_836Z-debug.log
还出现过运行上述指令后弹出一个github的框要求输入一个什么东西(我忘记了)
四、解决办法
直接装完整包
npm install regenerator-runtime
推荐阅读
-
VUE:使用async和await实现axios同步请求
-
axios 通过async和await实现同步
-
vue中使用async、await和promise实现异步API的同步调用
-
使用 async 和 await,实现 fetch 同步请求
-
vue 使用 async 和 await 实现异步 axios 同步化(实战案例:数据异步校验通过后,再执行保存)
-
vue 中使用 async/await 将 axios 异步请求同步化处理
-
微信小程序 ———— 异步请求中使用async/await实现同步请求
-
react通过axios请求数据,用一个bol来判断数据是否加载完成后,渲染在页面上,不用async await和定时器的更好方法
-
微信小程序中使用Async-await方法异步请求变为同步请求方法
-
微信小程序中使用Async-await方法异步请求变为同步请求方法