Javascript 将一个函数中的局部变量返回给另一个函数

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

我正在使用Angular构建一个脱机HTML页面,并使用ydn db进行脱机存储

我有这样的数据库服务

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;}但不起作用。我返回了数据库,然后检查它是否在范围内完成。