こちらを参考にsqfliteを学習しております。
参考にしたページ
したいことは
getMemos()をListView.builderで表示させたいです。
不明な点は、
getMemosの型がよくわかりません。(list型を返している関数だと思いますが、空List=getMemos()の様にしたいのですが空Listの型でうまくいきません。)
どのような宣言になるでしょうか?
また、ListView.builderの返り値にはその空Listを置けばいいと思っていますが、合っておりますでしょうか?
よろしくお願い致します。
ListView.builder( shrinkWrap: true, //追加 physics: const NeverScrollableScrollPhysics(), //追加 itemCount: 空List.length, itemBuilder: (context,int index){ return [???] }, )
以下メモクラスを引用
class Memo { final int id; final String text; Memo({this.id, this.text}); Map<String, dynamic> toMap() { return { 'id': id, 'text': text, }; } static Future<Database> get database async { // openDatabase() データベースに接続 final Future<Database> _database = openDatabase( // getDatabasesPath() データベースファイルを保存するパス取得 join(await getDatabasesPath(), 'memo_database.db'), onCreate: (db, version) { return db.execute( // テーブルの作成 "CREATE TABLE memo(id INTEGER PRIMARY KEY AUTOINCREMENT, text TEXT)", ); }, version: 1, ); return _database; } static Future<void> insertMemo(Memo memo) async { final Database db = await database; await db.insert( 'memo', memo.toMap(), conflictAlgorithm: ConflictAlgorithm.replace, ); } static Future<List<Memo>> getMemos() async { final Database db = await database; final List<Map<String, dynamic>> maps = await db.query('memo'); return List.generate(maps.length, (i) { return Memo( id: maps[i]['id'], text: maps[i]['text'], ); }); } }
回答1件
あなたの回答
tips
プレビュー
バッドをするには、ログインかつ
こちらの条件を満たす必要があります。