gpt4 book ai didi

json - Flutter:使用共享首选项插件存储保存的收藏夹列表

转载 作者:行者123 更新时间:2023-12-03 04:42:56 25 4
gpt4 key购买 nike

以下是我的JSON文件,其中包含数据:

[
{
"city": "City1",
"attractions": [
"attraction1",
"attraction2"
],
},
{
"city": "city2",
"attractions": [
"attraction1",
"attraction2",
],
},
]
我的实现代码是一个列表 View 构建器,该构建器从JSON文件获取数据。该代码还具有将城市另存为收藏夹的选项,可以在另一页中显示为已保存的收藏夹列表:
class Index extends StatefulWidget {
@override
_IndexState createState() => _IndexState();
}
List data;
List<Cities> citylist = List();
List<Cities> citysavedlist = List();
int index;
class _IndexState extends State<Index> {
@override
Widget build(BuildContext context) {
return Scaffold(
appBar: AppBar(),
body: listView(),
);
}
Future<String> fetchData() async {
String data =
await DefaultAssetBundle.of(context).loadString("assets/data.json");
final jsonResult = json.decode(data);
this.setState(() {
jsonResult
.forEach((element) => citylist.add(new Cities.fromJson(element)));
});
return "Success!";
}

@override
void initState() {
super.initState();
fetchData();
}

listView() {
return ListView.builder(
itemCount: citylist == null ? 0 : citylist.length,
itemBuilder: (context, index) {
return Column(
children: <Widget>[_buildRow(index, citylist)],
);
},
);
}

Widget _buildRow(index, citylist) {
final bool alreadySaved = citysavedlist.contains(citylist[index]);
return Padding(
padding: const EdgeInsets.only(top: 5.0, left: 5.0, right: 5.0),
child: Card(
child: ListTile(
title:
Text(citylist[index].title, style: TextStyle(fontSize: 22.0)),
trailing: IconButton(
icon: Icon(
alreadySaved ? Icons.star : Icons.star_border,
color: alreadySaved ? Colors.blue : Colors.blue,
),
onPressed: () {
setState(() {
if (alreadySaved) {
citysavedlist.remove(citylist[index]);
} else {
citysavedlist.add(citylist[index]);
}
});
},
), //subtitle: Text(subtitle),
onTap: () {
Navigator.push(
context,
MaterialPageRoute(
builder: (context) => Detail(citylist[index])));
}),
),
);
}


void _pushSaved() {
Navigator.of(context).push(
MaterialPageRoute<void>(
builder: (BuildContext context) {
final Iterable<ListTile> tiles = citysavedlist.map(
(Cities pair) {
return ListTile(
title: Text(
pair.city,
),
onTap: () {
Navigator.push(context,
MaterialPageRoute(builder: (context) => Detail(pair)));
});
},
);

final List<Widget> divided = ListTile.divideTiles(
context: context,
tiles: tiles,
).toList();
return Scaffold(
appBar: AppBar(
title: const Text('Saved Suggestions'),
),
body: ListView(children: divided),
);
},
),
);
}
}
这是模型类:
List<Cities> citiesFromJson(String str) =>
List<Cities>.from(json.decode(str).map((x) => Cities.fromJson(x)));
String citiesToJson(List<Cities> data) =>
json.encode(List<dynamic>.from(data.map((x) => x.toJson())));

class Cities {
Cities({
this.city,
this.attractions,
});

String city;
List<String> attractions;

factory Cities.fromJson(Map<String, dynamic> json) => Cities(
city: json["city"],
attractions: List<String>.from(json["attractions"].map((x) => x)),
);

Map<String, dynamic> toJson() => {
"city": city,
"attractions": List<dynamic>.from(attractions.map((x) => x)),
};
}
现在,我面临一个问题,即已保存的收藏夹城市未存储,因此当应用程序关闭并再次重新打开时,收藏夹列表将因为未存储而消失。
我知道有一个名为 Shared preferences的插件可以执行此功能来存储保存的数据,但是我无法将该插件集成到我的代码中。有人可以帮忙吗?

最佳答案

首先,您需要在pubspec中获取软件包,然后

import 'package:shared_preferences/shared_preferences.dart';

SharedPreferences prefs = await SharedPreferences.getInstance();
现在要保存的json数据是
prefs.setString('mydata', json.encode(yourjsondata));
检索此数据
您必须使用分配的确切名称,在我的情况下为'mydata'
json.decode(preferences.getString('mydata'))
请记住,如果您想保存那么多数据项,建议使用sqflite或hive,或者如果您仍想使用shared_preferences,则可以将计数器另存为
保存
var counter = (prefs.getInt('Counter')??0)+1;
prefs.setString('Counter:$counter', json.encode(yourdata));
恢复订单
var listCount = preferences.getInt('Counter');
使用listCount循环,然后使用
json.decode(preferences.getString('Counter:$variable'))

关于json - Flutter:使用共享首选项插件存储保存的收藏夹列表,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/62840324/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com