我尝试使用工厂从数据库中获取数据。 我有一个问题,因为我不知道如何从工厂返回的对象中获取数据。这是我在使用console.log()函数时收到的:
>d {$$state: Object}
$$state: Object
status: 1
value: Array[1]
__proto__: Object
__proto__: Object
这是我的工厂代码:
application.factory('Database', ['$http', function($http) {
var databaseFactory = {};
databaseFactory.get = function(query) {
return $http.get("getData.php", {params: {'query': query}}, {headers: {'Content-Type': 'application/x-www-form-urlencoded'}})
.then(function (response) {
databaseFactory.returnedData = response.data;
return databaseFactory.returnedData;
})
}
return databaseFactory;
}]);
这是我的控制器代码:
registration.controller('RegistrationController', ['$scope', 'Database', function($scope, Database) {
$scope.posts = Database.get("SELECT * FROM `group`");
console.log($scope.posts);
}]);
答案 0 :(得分:2)
一旦收到AJAX响应,您应该从控制器传递回调函数并在工厂中执行它。您可以将代码更新为以下内容。
<强>工厂强>
application.factory('Database', ['$http', function($http) {
var databaseFactory = {};
databaseFactory.get = function(query, callback) {
return $http.get("getData.php", {params: {'query': query}}, {headers: {'Content-Type': 'application/x-www-form-urlencoded'}})
.then(function (response) {
databaseFactory.returnedData = response.data;
callback(databaseFactory.returnedData);
})
}
return databaseFactory;
}]);
<强>控制器强>
registration.controller('RegistrationController', ['$scope', 'Database', function($scope, Database) {
Database.get("SELECT * FROM `group`", function(resp){
$scope.posts = resp;
console.log($scope.posts);
});
}]);
答案 1 :(得分:2)
它回复了一个承诺,你需要这样处理它
在你的控制器中添加:
getSomething.getBla().then(function(response) {
console.log(response.data)
});
了解更多信息:&#39; http://andyshora.com/promises-angularjs-explained-as-cartoon.html&#39;
答案 2 :(得分:0)
这适用于我的情况:结果。$$ state.value。
示例代码: 的控制器:强>
promise = getConfigService.getAccount(protocol+hostName+port);
promise
.then(
function (result) {
var baseUrlTemp = result.$$state.value.baseURL;
console.log("BaseURL:"+baseURLTemp)
}
<强>输出继电器:强> BaseURL:www.oneindia.com