实现同步重点在于添加async、await,且后台请求方法与调用者都需要添加,也就是添加两组,经测试单独添加任何一组都无效
axios封装的请求, user.js
import axios from '@/libs/api.request'
export const getAllUser = (data) => {
return axios.request({
url: 'user/mgt/getAllUser',
method: 'post',
data: data
})
}
方法调用与同步请求
import { getAllUser } from '@/api/user'
// 方法调用
async getList(){
let _this = this
await getAllUser({
queryParams: JSON.stringify(this.search),
type: 1
}).then(res => {
debugger
let { data, total } = res.data.data
this.list = {
data: data,
total: total,
loading: false
}
}).catch(err => {
console.log(err)
})
},
// 调用getList方法
async showModal (name, userIds, userNames) {
this.modal.visible = true
this.selectData.ids = userIds
this.selectData.alias = userNames
await this.getList(userIds)
debugger
let users = []
if (userIds && this.list.data) {
users = userIds.split(",")
users.forEach((item, index, users) => {
for (let i=0;i<this.list.data.length;i++) {
debugger
if (this.list.data[i].id === item) {
this.$refs.table.$refs.tbody.objData[i]._isChecked = true;
}
}
})
}
},
说明:因为需要getList()方法执行完成之后才允许执行let users = []之后的代码,所以getList()必须要加同步,代码中debugger调试后会发现先执行完axios请求并且从服务器返回数据之后才执行下面的代码