如何将对象从使用PouchDB的工厂返回到控制器

How to return an object to the controller from a factory that uses PouchDB

本文关键字:工厂 返回 控制器 PouchDB 对象      更新时间:2023-09-26

我创建了一个angularJS工厂,用于插入IndexedDB并从中获取一些值。我可以成功地将值插入IndexedDB。但是,当我试图从DB中获取值并将其传递给控制器时,我会遇到问题。

factory.getAllProgressData = function() {
        var dbOptions = {};
        dbOptions.include_docs = true;
        var output = {};
        var result = {};
        pouchDb.allDocs(dbOptions, function(err, res) {
            if (err)
                console.log(err);
            if(res) {               
                output.weight = getWeightValues(res.rows);  
                console.log(output);    // <== This console line prints the object
            }
        });
        console.log(output);    // <== This console line does NOT print the object
        return output;
};
var getWeightValues = function(rows) {
        var weightValues = [];
        for (var i = 0; i < rows.length; i++) {
            weightValues.push(rows[i].doc.Weight);
        };
        return weightValues;
    };

正如您在代码的注释中所看到的,当我将对象打印到控制台的第一个位置时,它就会打印出来。但当我试着在下面做的时候,它不会打印出来。返回值也是空的。我对javascript很陌生,这种行为我不清楚。我希望结果对象返回到Controller。请帮忙。提前谢谢。

只是猜测,但答案可能是因为pouchDb.allDocs是一个异步函数。这可能是一个学习编写异步JavaScript(又名AJAX)的好机会。AJAX对于那些刚接触JavaScript的人来说是一个很难理解的概念。

例如,您应该能够清楚地了解打印到控制台的内容以及以下代码中的顺序:

function printB() { console.log('B'); }
console.log('A');
setTimeout(printB, 10);
console.log('C');

答案是ACB,而不是ABC,也不是BAC。如果你明白为什么,你就可以很好地回答自己的问题了。

一个稍微相关的例子:

var a = 'A';
function changeAtoB() { a = 'B'; console.log(a); }
console.log(a);
setTimeout(changeAtoB, 10);
console.log(a);

答案是AAB,而不是ABA,原因与前面的例子相同。此外,请注意,setTimeout做了一件特定的事情,但它是异步函数概念的一个很好的一般介绍性示例。

为了更直接地解决您的问题,第二个示例对应于为什么您的输出变量可能是为console.log的一个调用而定义的,而不是为另一个调用。