我有以下代码,该代码创建一个Listview并在每个项目的末尾添加一个图标。可以点按此图标以使其突出显示。
问题是,当我离开页面导航时,这些项目被取消选择。我正在使用Navigator.of
加载Listview:
Navigator.of(context)
.push(MaterialPageRoute<Null>(builder: (BuildContext context) {
return new LikedList();
}));
完整代码:
import 'package:flutter/material.dart';
import './images.dart';
class LikedList extends StatefulWidget {
@override
_LikedListState createState() => _LikedListState();
}
class _LikedListState extends State<LikedList> {
List<bool> _likes = List.filled(ImagesState.likes.length,true);
@override
Widget build(BuildContext context) {
return Scaffold(
appBar: AppBar(
title: Text('Liked List'),
),
body: ListView.separated(
separatorBuilder: (context, index) => Divider(),
itemCount: ImagesState.likes.length,
itemBuilder: (context, index) {
final item = ImagesState.likes[index];
return ListTile(
title: Text(item),
trailing: IconButton(
icon: _likes[index]
? Icon(
Icons.favorite_border,
color: Colors.grey,
)
: Icon(
Icons.favorite,
color: Colors.red,
),
onPressed: () {
setState(() {
print(_likes);
_likes[index] = !_likes[index];
print(_likes);
});
},
),
onLongPress: () {
setState(() {
print(ImagesState.likes[index]);
ImagesState.likes.removeAt(index);
});
},
);
},
),
);
}
}