あなたのonCursor()
関数が何をしているのか/何を呼び出しているのかわかりません。あなたの値の変数はリストであると仮定しています。
私も似たようなことをしていますが、フューチャ/コンプリータの代わりにコールバックを使用しています。ここには小さな関数フラグメントしかありません。うまくいけばいくつかの詳細を追加するために、いくつかをフラッシュします。
// Accept the indexeddb Database, and return a future which
// will provide the list of values from 'someKey'
Future<List<String>> getSomeKeyValues(Database db) {
var values = new List<String>();
var completer = new Completer();
var store = db.transaction('DB_STORE', 'readwrite').objectStore('DB_STORE');
store.openCursor(autoAdvance: true).listen((cursor) {
if(cursor != null && cursor.value != null) {
// Note cursor.value is actually a Map<String, String>
// of collection's key and value
values.add(cursor.value['someKey']); // get the value key 'someKey'
}
}, onDone: () => completer.complete(values),
onError: (e) => completer.completeError(e));
return completer.future;
}
次に、この関数を次のように呼び出します。
getSomeKeyValues(myDatabase).then((results) {
for(var value in results) {
print(value);
}
}