在我的Flutter应用程序中
我想在一个listView中显示多个项目。
我想使用Provider来处理他们的状态。
但我如何处理状态的方式,如果我编辑列表视图中的一个项目,只有该项目得到重建。
而整个列表视图只有在我通过添加或删除改变项目数量时才会被重建。
我怎样才能做到这一点呢?
这是一个工作解决方案,非常接近你想要的东西(它仍然重建整个 ListView
当一个项目被编辑后,却不用担心效率问题,因为。ListView.builder
照顾你)。)
import 'package:flutter/material.dart';
import 'package:provider/provider.dart';
class MyModel {
int modelNumber;
MyModel(this.modelNumber);
void edit(int newModelNumber) {
modelNumber = newModelNumber;
}
}
class MyModelListWrapper with ChangeNotifier {
List<MyModel> modelsList;
MyModelListWrapper(this.modelsList);
void add(MyModel model) {
modelsList.add(model);
notifyListeners();
}
void removeAt(int index) {
modelsList.removeAt(index);
notifyListeners();
}
void editModelNumber(int index,int newModelNumber){
modelsList[index].edit(newModelNumber);
notifyListeners();
}
}
void main() => runApp(MyApp());
class MyApp extends StatelessWidget {
@override
Widget build(BuildContext context) {
return MultiProvider(
providers: [
ChangeNotifierProvider(
create: (_) => MyModelListWrapper(
[...List.generate(15, (index)=>MyModel(index))]),
),
],
child: MaterialApp(
home: HomePage(),
),
);
}
}
class HomePage extends StatelessWidget {
@override
Widget build(BuildContext context) {
return Scaffold(
appBar: AppBar(),
body: Consumer<MyModelListWrapper>(
builder: (_,myModelsListWrapper,__)=> ListView.builder(
itemCount: myModelsListWrapper.modelsList.length,
itemBuilder: (ctx, index) => ListTile(
title: Text('${myModelsListWrapper.modelsList[index].modelNumber}'),
onTap: (){
// myModelsListWrapper.editModelNumber(index, -1);
myModelsListWrapper.removeAt(index);
//or do any other action you want
},
),
),
),
);
}
}