项目场景:

动态获取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
},

更多推荐

获取ajax返回值