$scope.openDocImg = function(id, e){
var data = [];
...
$http.post("/showDocument", cid).then(function(response){
data = response.data.slice(0);
console.log(data);
});
console.log(data.length); //displays 0
console.log(data);
...
}
我不完全理解为什么post方法中的数据充满内容,而外部没有。是因为函数内部和外部的变量作用域?
该如何将内容复制到外部作用域?
答案 0 :(得分:1)
由于$http.post
方法是异步执行的,因此console.log(data.length);
语句是在您从服务器接收响应之前执行的。
所以这就是为什么当您尝试记录0
的长度时收到data
的原因。
您应该使用callback
函数。
function postRequest(callback){
$http.post("/showDocument", cid).then(function(response){
callback(response.data.slice(0));
});
}
$scope.openDocImg = function(id, e){
var data = [];
...
postRequest(function(data){
console.log(data.length);
console.log(data);
});
...
}