目前,我通过使用Angularjs框架开发cordova应用程序。我想获得价值返回$ cordovaSQLite.execute()函数。通常,我使用.then(result())通过$ cordovaSQLite.execute()获得return的值。但是,.then(result())函数的结果值不能在.then(result())外部使用。对我来说,获取诸如result.rows.item(0).UserName;之类的价值的任何解决方案吗?我的.then(result())函数之外。以下是我的代码。
var channelNameQuery = "SELECT * FROM chat_friend WHERE UserName=?"
var channelNamePromise = $cordovaSQLite.execute(db, channelNameQuery, [channelName]).then(function (result){
var abc = result.rows.item(0).UserName;
console.log(abc);
})
接下来,我尝试使用以下代码来获取ChannelNamePromise值。它无法获得价值。
var abc = channelNamePromise.rows.item(0).UserName;
console.log(abc);
最佳答案
你可以这样
让我们在AppCtrl内创建一个全局方法,以便可以在多个控制器中使用它。
.controller('AppCtrl', function ($scope,$rootScope) {
$rootScope.getFromDB = function (channelName) {
var deferred = $q.defer();
var items = [];
var query = "SELECT * FROM chat_friend WHERE UserName=?";
$cordovaSQLite.execute(db, query, [channelName]).then(function (res)
{
for (var index = 0; index < res.rows.length; index++) {
var item = res.rows.item(index);
items.push(item);
}
deferred.resolve(items);
}, function (err) {
deferred.reject(items);
console.error(err);
});
return deferred.promise;
};
})
现在在您的控制器中
.controller('ExampleCtrl', function ($scope,$rootScope) {
$rootScope.getFromDB('yourChannelName').then(function (data) {
console.log('Result'+data); //success block, do whatever you want
});
})
您还可以将结果分配给任何数组,像这样
.controller('ExampleCtrl', function ($scope,$rootScope) {
$scope.resultArr = $rootScope.getFromDB('yourChannelName').then(function (data) {
$scope.resultArr = result; //do whatever you want here
});
//outside then block you can use it.
console.log("Result"+ $scope.resultArr);
})
关于javascript - Cordova Angularjs:如何从CordovaSQLite获得值(value)返回,我们在Stack Overflow上找到一个类似的问题:https://stackoverflow.com/questions/42287921/