项目场景:
动态获取ajax返回值:
在表格数据内根据相关表格内容获取不同的列表
问题描述:
let deptList = that.getDeptList(id)
获取到ajax的返回值是undefined
getDeptList(id){
let that = this
let list = []
$.ajax({
async:false,
type: "GET",
url: "/#?organizeId="+id,
success: function (res) {
var obj = JSON.parse(res);
for(let i in obj){
list.push(obj[i])
if(obj[i].ChildNodes.length>0){
for(let j in obj[i].ChildNodes){
info = obj[i].ChildNodes[j]
info.text = obj[i].text+'>>'+info.text
list.push(info)
}
}
}
return list
}
});
},
原因分析:
例如:ajax是异步回调的,但获取值的时候是同步函数。
解决方案:
把这个async:false,
加入ajax调用中,将Ajax异步改为同步,并在方法最底部回调ajax的值,例如:
getDeptList(id){
let that = this
let list = []
$.ajax({
async:false,
type: "GET",
url: "/#?organizeId="+id,
success: function (res) {
var obj = JSON.parse(res);
for(let i in obj){
list.push(obj[i])
if(obj[i].ChildNodes.length>0){
for(let j in obj[i].ChildNodes){
info = obj[i].ChildNodes[j]
info.text = obj[i].text+'>>'+info.text
list.push(info)
}
}
}
}
});
return list
},
版权声明:本文为weixin_43097497原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。