Flutter支持Preferences(Shared Preferences and NSUserDefaults) 厢洞、文件、和Sqlite3丧叽。若想使用這個功能需要引入官方倉庫的相應插件公你,下面詳細介紹這三種存儲方式的使用方法。
Preferences
等同iOS的NSUserDefaults和Android的SharedPreferences迂尝。
導入插件
- 打開項目的pubspec.yaml配置剪芥,在dependencies節(jié)點下新增配置:
shared_preferences: ^0.4.1
- 點擊開發(fā)工具提示的packages get按鈕或者在命令行輸入flutter packages get來同步第三方插件
- 在Dart文件中引入插件
import 'package:shared_preferences/shared_preferences.dart';
Flutter支持的全部插件: https://github.com/flutter/plugins
使用示例
setUserName() async{
SharedPreferences prefs = await SharedPreferences.getInstance();
prefs.setString(mUserName,"小明");
}
getUserName() async{
SharedPreferences prefs = await SharedPreferences.getInstance();
userName = prefs.getString(mUserName);
}
displayUserName() {
Future<String> userName = getUserName();
userName.then((String userName) {
Scaffold.of(context).showSnackBar(
SnackBar(content: Text("數據獲取成功:$userName")));
});
}
文件存儲
導入插件
- 打開項目的pubspec.yaml配置粗俱,在dependencies節(jié)點下新增配置:
path_provider: ^0.4.0
- 點擊開發(fā)工具提示的packages get按鈕或者在命令行輸入flutter packages get來同步第三方插件
- 在Dart文件中引入插件
import 'package:path_provider/path_provider.dart';
使用示例
獲取文件路徑方法:
- 獲取應用緩存目錄: getTemporaryDirectory
- 類似iOS的NSTemporaryDirectory和Android的getCacheDir
- 獲取應用文件目錄: getApplicationDocumentsDirectory
- 類似iOS的NSDocumentDirectory和Android上的AppData目錄
- 應用程序被刪除時,系統會清除目錄
- 存儲卡: getExternalStorageDirectory
- 僅支持Android平臺
?// 找到正確的本地路徑
Future<String> get _localPath async {
final directory = await getApplicationDocumentsDirectory();
return directory.path;
}
// 創(chuàng)建對文件位置的引用
Future<File> get _localFile async {
final path = await _localPath;
return new File('$path/counter.txt');
}
// 將數據寫入文件
Future<File> writeCounter(int counter) async {
final file = await _localFile;
// Write the file
return file.writeAsString('$counter');
}
// 從文件中讀取數據
Future<int> readCounter() async {
try {
final file = await _localFile;
// Read the file
String contents = await file.readAsString();
return int.parse(contents);
} catch (e) {
// If we encounter an error, return 0
return 0;
}
}
Sqfite
SQLite plugin for Flutter. Get the default databases location. On Android, it is typically data/data/<package_name>/databases, On iOS, it is the Documents directory.
導入插件
- 打開項目的pubspec.yaml配置,在dependencies節(jié)點下新增配置:
sqflite: ^1.0.0
- 點擊開發(fā)工具提示的packages get按鈕或者在命令行輸入flutter packages get來同步第三方插件
- 在Dart文件中引入插件
import 'package:sqflite/sqflite.dart';
使用示例
// 獲取數據庫文件的存儲路徑
var databasesPath = await getDatabasesPath();
String path = join(databasesPath, 'demo.db');
// 創(chuàng)建數據庫表
db = await openDatabase(path, version: 1,
onCreate: (Database db, int version) async {
await db.execute('''
CREATE TABLE $tableBook (
$columnId INTEGER PRIMARY KEY,
$columnName TEXT,
$columnAuthor TEXT,
$columnPrice REAL,
$columnPublishingHouse TEXT)
''');
});
// 插入數據
Future<int> rawInsert(String sql, [List<dynamic> arguments]);
Future<int> insert(String table, Map<String, dynamic> values,
{String nullColumnHack, ConflictAlgorithm conflictAlgorithm});
// 查詢數據
Future<List<Map<String, dynamic>>> rawQuery(String sql,
[List<dynamic> arguments]);
Future<List<Map<String, dynamic>>> query(String table,
{bool distinct,
List<String> columns,
String where,
List<dynamic> whereArgs,
String groupBy,
String having,
String orderBy,
int limit,
int offset});
// 更新數據
Future<int> rawUpdate(String sql, [List<dynamic> arguments]);
Future<int> update(String table, Map<String, dynamic> values,
{String where,
List<dynamic> whereArgs,
ConflictAlgorithm conflictAlgorithm});
// 刪除
Future<int> rawDelete(String sql, [List<dynamic> arguments]);
Future<int> delete(String table, {String where, List<dynamic> whereArgs});
// 關閉數據庫
Future close() async => db.close();
參考文檔
Flutter中的本地存儲
Flutter數據存儲之shared_preferences
Flutter 構建完整應用手冊-持久化
Flutter持久化存儲之數據庫存儲