Javascript 将一个函数中的局部变量返回给另一个函数
我正在使用Angular构建一个脱机HTML页面,并使用ydn db进行脱机存储 我有这样的数据库服务Javascript 将一个函数中的局部变量返回给另一个函数,javascript,angularjs,scope,angularjs-service,ydn-db,Javascript,Angularjs,Scope,Angularjs Service,Ydn Db,我正在使用Angular构建一个脱机HTML页面,并使用ydn db进行脱机存储 我有这样的数据库服务 demoApp.SericeFactory.database = function database() { var database = { dataStore: null, admins: [], students: [], errors: [], getadmindata: function(use
demoApp.SericeFactory.database = function database() {
var database = {
dataStore: null,
admins: [],
students: [],
errors: [],
getadmindata: function(username) {
self = null, that = this
database.dataStore.get('admins', username).done(function(record) {
that.self = record;
return record;
}).fail(function(e) {
console.log(e);
database.errors.push(e);
});
return self; //This does not change.
}
};
database.dataStore = new ydn.db.Storage('DemoApp');
angular.forEach(INITSTUDENTS, function(student) {
database.dataStore.put('students', student, student.matricno);
database.students.push(student);
});
angular.forEach(INITADMINS, function(admin) {
database.dataStore.put('admins', admin, admin.username);
database.admins.push(admin);
});
return database;
我还有一个试图使用数据库的控制器
function AppCntl ($scope, database) {
var user = database.getadmindata('user'); //I get nothing here.
}
我所尝试的,
我试着让自己变成另一个自己
我尝试过像这样拆分函数
rq = database.dataStore.get('admins', 'user');
rq.done(function(record), {
self = record;
alert(self.name) //Works.
});
alert(self) //Doesn't work.
我曾经遇到过像StackOverflow这样的问题,但似乎什么都不适合我,或者可能我只是找错了地方。数据库请求是异步的,因此它在代码执行结束后执行 因此,当执行最后一个警报时,self仍然未定义。Secound警报在db请求完成后执行,这通常是正确的设计模式 编辑: 我成功地使用了以下代码:
// Database service
angular.module('myApp.services', [])
.factory('database', function() {
return new ydn.db.Storage('feature-matrix', schema);
}
});
// controller using database service
angular.module('myApp.controllers', [])
.controller('HomeCtrl', ['$scope', 'utils', 'database', function($scope, utils, db) {
var index_name = 'platform, browser';
var key_range = null;
var limit = 200;
var offset = 0;
var reverse = false;
var unique = true;
db.keys('ydn-db-meta', index_name, key_range, limit, offset, reverse, unique)
.then(function(keys) {
var req = db.values('ydn-db', keys);
req.then(function(json) {
$scope.results = utils.processResult(json);
$scope.$apply();
}, function(e) {
throw e;
}, this);
});
}])
完整的应用程序可在
正在运行的演示应用程序位于此处:谢谢。我必须检查是否使用$scope.$$phase{$scope.$digest;}但不起作用。我返回了数据库,然后检查它是否在范围内完成。