<em>Mac</em>Book项目 2009年学校开始实施<em>Mac</em>Book项目,所有师生配备一本<em>Mac</em>Book,并同步更新了校园无线网络。学校每周进行电脑技术更新,每月发送技术支持资料,极大改变了教学及学习方式。因此2011
2021-06-01 09:32:01
shared_preferences
類比iOS中的UserDefaults
,使用方法比較簡單。 地址戳這裡 pub get
之後會自動出現一個這樣的檔案generated_plugin_registrant.dart
資料儲存:
void _incrementCounter() { //建立物件,用於操作儲存和讀取。 SharedPreferences.getInstance().then((SharedPreferences prefs) { setState(() { _counter++; }); prefs.setInt('counter', _counter); }); }
資料讀取:
SharedPreferences.getInstance().then((SharedPreferences prefs) { setState(() { _counter = prefs.getInt('counter') ?? 0; }); });
使用sqlite需要搭配著path一起使用,在使用的過程中踩了一個坑, 明明我安裝了CocoaPods
卻一直提示我CocoaPods not installed
Warning: CocoaPods not installed. Skipping pod install.
CocoaPods is used to retrieve the iOS and macOS platform side's plugin code
that responds to your plugin usage on the Dart side.
Without CocoaPods, plugins will not work on iOS or macOS.
For more info, see https://flutter.dev/platform-plugins To install
see https://guides.cocoapods.org/using/getting-started.html#installation for instructions.
最後解決辦法 1;開啟終端 2; 輸入open /Applications/Android Studio.app
即可。感覺挺奇怪的一個錯誤 感謝大佬,問題解決連結
1.getDatabasesPath
來到了Documents
下的目錄 2.join(value, 'test_db.db')
使用的是一個path
的pub庫配合使用 3.openDatabase
開啟資料庫,onCreate
建表 // 建表 CREATE TABLE 表名(,,)
late Database _db; @override void initState() { super.initState(); _initDatabase().then((value) => _db = value); } Future<Database> _initDatabase() async { Database db = await getDatabasesPath() .then((value) => join(value, 'test_db.db')) .then((value) => openDatabase(value, version: 1, onCreate: (Database db, int version) async { // 建表 await db.execute( 'CREATE TABLE LK_Text(id INTEGER PRIMARY KEY,name TEXT, age INT)'); })); return db; }
Future<String> getDatabasesPath() => databaseFactory.getDatabasesPath();
是一個Future
所以需要async
配合著await
來使用。 執行之後發現已經建立成功了,大小8kb, 是一個空表。
_db插入資料可以使用事務處理
// 新增資料 INSERT INTO 表名 VALUES (值1,值2,...)
_db.transaction((txn) async { txn .rawInsert('INSERT INTO LK_Text(name,age) VALUES("zhangsan",16)') .then((value) => print(value)); txn .rawInsert('INSERT INTO LK_Text(name,age) VALUES("lisi",17)') .then((value) => print(value)); });
// 資料查詢 SELECT 列名稱 FROM 表名稱 *萬用字元
_db.rawQuery('SELECT * FROM LK_Text').then((value) => print(value));
// 修改資料 UPDATE 表名稱 SET 列名稱 = 新值 WHERE 列名稱 = 某值
_db.rawUpdate('UPDATE LK_TEXT SET age = 18 WHERE age = 16');
1._db.delete
刪除表 2._db.close()
關閉資料庫
_db .rawQuery('SELECT * FROM LK_Text') .then((value) => print(value)) .then((value) { // 刪除表 _db.delete('LK_Text').then((value) => _db.close()); });
切記:由於這裡是非同步的操作,注意執行的順序!! 校驗的話還是很簡單,再次寫入資料的時候會報錯。
// 刪除資料庫 getDatabasesPath() .then((value) => join(value, 'test_db.db')) .then((value) => deleteDatabase(value));
整體來說還是比較簡單的,主要是把sqlite
語句寫正確。
以上就是ios開發Flutter之資料儲存的詳細內容,更多關於ios Flutter資料儲存的資料請關注it145.com其它相關文章!
相關文章
<em>Mac</em>Book项目 2009年学校开始实施<em>Mac</em>Book项目,所有师生配备一本<em>Mac</em>Book,并同步更新了校园无线网络。学校每周进行电脑技术更新,每月发送技术支持资料,极大改变了教学及学习方式。因此2011
2021-06-01 09:32:01
综合看Anker超能充系列的性价比很高,并且与不仅和iPhone12/苹果<em>Mac</em>Book很配,而且适合多设备充电需求的日常使用或差旅场景,不管是安卓还是Switch同样也能用得上它,希望这次分享能给准备购入充电器的小伙伴们有所
2021-06-01 09:31:42
除了L4WUDU与吴亦凡已经多次共事,成为了明面上的厂牌成员,吴亦凡还曾带领20XXCLUB全队参加2020年的一场音乐节,这也是20XXCLUB首次全员合照,王嗣尧Turbo、陈彦希Regi、<em>Mac</em> Ova Seas、林渝植等人全部出场。然而让
2021-06-01 09:31:34
目前应用IPFS的机构:1 谷歌<em>浏览器</em>支持IPFS分布式协议 2 万维网 (历史档案博物馆)数据库 3 火狐<em>浏览器</em>支持 IPFS分布式协议 4 EOS 等数字货币数据存储 5 美国国会图书馆,历史资料永久保存在 IPFS 6 加
2021-06-01 09:31:24
开拓者的车机是兼容苹果和<em>安卓</em>,虽然我不怎么用,但确实兼顾了我家人的很多需求:副驾的门板还配有解锁开关,有的时候老婆开车,下车的时候偶尔会忘记解锁,我在副驾驶可以自己开门:第二排设计很好,不仅配置了一个很大的
2021-06-01 09:30:48
不仅是<em>安卓</em>手机,苹果手机的降价力度也是前所未有了,iPhone12也“跳水价”了,发布价是6799元,如今已经跌至5308元,降价幅度超过1400元,最新定价确认了。iPhone12是苹果首款5G手机,同时也是全球首款5nm芯片的智能机,它
2021-06-01 09:30:45