将数据库提供程序导入到另一个文件提供程序中,Dart语言。

3

我希望在多个独立的提供程序文件中使用我的数据库连接提供程序。

如何将我的DBProvider(mainProvider.dart)导入其中一个文件(例如langProvider.dart)?

以下是两者的代码。

mainProvider.dart

class DBProvider{
  static Database? _database;
  static final DBProvider db = DBProvider._();

  DBProvider._();

  Future<Database> get database async{
    _database ??= await initDB();

    return _database!;
  }

  Future<Database> initDB() async{
    Directory documentDirectory = await getApplicationDocumentsDirectory();

    final path = join(documentDirectory.path, 'assets/database/myDB.db');
    await deleteDatabase(path);
    debugPrint(path);

    var existsDB = await databaseExists(path);

    if(!existsDB){
      try{
        await Directory(dirname(path)).create(recursive: true);
      } catch(_){}

      ByteData data = await rootBundle.load(join('assets/database/myDB.db'));
      List<int> bytes = data.buffer.asUint8List(data.offsetInBytes, data.lengthInBytes);

      await File(path).writeAsBytes(bytes, flush: true);
    }

    var db = await openDatabase(path);
    return db;
  }
}

langProvider.dart

import 'package:flutter_demo_app/src/providers/provider.dart';
import 'package:flutter_demo_app/src/models/lang_model.dart';

  Future<List<langModel>> getAllLangs() async{
    Database db = await database;
    final result = await db.query('languages');

    return result.isNotEmpty ? result.map((langs) => langModel.fromJson(langs)).toList() : [];
  }

  Future<langModel?> getLangById(int id) async{
    Database db = await database;
    final result = await db.query('languages', where: 'id = ?', whereArgs: [id]);

    return result.isNotEmpty ? langModel.fromJson(result.first) : null;
  }
1个回答

1
使用ProxyProviderDBProvider设置到其他提供程序中。它应该是这样的:
MultiProvider(providers: [
  Provider(create: (context) => DBProvider),
  ProxyProvider<DBProvider, LangProvider>(
    create: (context) => LangProvider(),
    update: (context, dbProvider, langProvider) =>
        langProvider..setDBProvider(dbProvider),
  ),
]),

在LangProvider中创建一个setter来接收DBProvider:
  DBProvider? _dbProvider;

  void setDBProvider(DBProvider dbProvider) {
    _dbProvider = dbProvider;
  }  

  Future<List<langModel>> getAllLangs() async{
    Database db = await _dbProvider!.database;
    final result = await db.query('languages');

    return result.isNotEmpty ? result.map((langs) => langModel.fromJson(langs)).toList() : [];
  }

  Future<langModel?> getLangById(int id) async{
    Database db = await _dbProvider!.database;
    final result = await db.query('languages', where: 'id = ?', whereArgs: [id]);

    return result.isNotEmpty ? langModel.fromJson(result.first) : null;
  }

网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接