我正在制作一个带有角2和电子的应用程序,并使用NeDB作为数据存储。
搜索服务的目的是使用DB处理操作,现在我希望它加载整个数据库并返回它。
search.service.ts
import { Injectable } from '@angular/core';
import * as Datastore from 'nedb';
import * as path from 'path';
@Injectable()
export class SearchService {
constructor() { }
getData(){
var db = new Datastore( {
filename: path.resolve('src/assets/db.json'),
autoload: true,
});
var result;
db.find({}, function(err, docs) {
result = docs;
});
console.log(result);
return result;
}
}在我的组件中,我使用一个方法在使用getData钩子初始化组件时调用服务的ngOnInit ()方法。
但是,当我记录结果时,我会得到undefined。
在修补搜索服务时,我发现我在find()方法中的find()是无法从方法外部访问的,而且似乎result = docs什么也不做。所以我想我需要一些异步魔法来完成这个任务。我想用可观察的方法来做这件事,但什么也做不到,很可能是做错了。
发布于 2017-07-07 09:23:48
find方法是异步的,回调函数不会立即执行,您可以使用以下承诺:
getData() {
var db = new Datastore({
filename: path.resolve('src/assets/db.json'),
autoload: true,
});
return new Promise((resolve, reject) => {
db.find({}, function(err, docs) {
if(err) reject(err);
resolve(docs);
});
})
}
someOtherFunc() {
this.getData()
.then((docs) => console.log(docs)) // here you will get it
.catch((err) => console.error(err));
}您可以了解更多有关承诺这里的信息。
如果您想使用可观察到的,您可以这样做:
getData() {
return new Rx.Observable(subscriber => {
var db = new Datastore({
filename: path.resolve('src/assets/db.json'),
autoload: true,
});
db.find({}, function(err, docs) {
if (err) subscriber.error(err);
subscriber.next(docs);
});
})
}
someOtherFunc() {
this.getData().subscribe(
data => console.log("success", data),
err => console.error("error", err)
)
}https://stackoverflow.com/questions/44966809
复制相似问题