【发布时间】:2019-11-15 03:05:13
【问题描述】:
我想解释一下 Flutter 中Provider package(使用ChangeNotifier 和ChangeNotifierProvider)和Scoped Model package 之间的区别。
看了这两种管理应用程序状态的方法后,我迷茫了,因为我没有发现代码编写方法有任何实质性差异。
作用域模型包使用:
class CounterModelWithScopedModel extends Model {
int _counter = 0;
int get counter => _counter;
void increment() {
_counter++;
notifyListeners();
}
}
class CounterAppWithScopedModel extends StatelessWidget {
@override
Widget build(BuildContext context) {
return new ScopedModel<CounterModelWithScopedModel>(
model: new CounterModelWithScopedModel(),
child: new Column(children: [
new ScopedModelDescendant<CounterModelWithScopedModel>(
builder: (context, child, model) => new Text('${model.counter}'),
),
new Text("Another widget that doesn't require scoped model")
])
);
}
}
提供程序包使用:
class CounterModelWithChangeNotifierProvider extends ChangeNotifier {
int _counter = 0;
int get counter => _counter;
void increment() {
_counter++;
notifyListeners();
}
}
class CounterAppWithChangeNotifierProvider extends StatelessWidget {
@override
Widget build(BuildContext context) {
return new ChangeNotifierProvider(
builder: (context) => CounterModelWithChangeNotifierProvider(),
child: new Column(children: [
new Consumer<CounterModelWithChangeNotifierProvider>(
builder: (context, model, child) => new Text('${model.counter}')
),
new Text("Another widget that doesn't require consume")
])
);
}
}
现在假设我们有另一个小部件使用increment(); 或CounterModelWithChangeNotifierProvider 和CounterAppWithScopedModel 触发通知并导致小部件被重建。
我最近接触了flutter,我对应用程序状态的管理感到很困惑,我从Notifier开始,但是在看到有无数种方法之后我不知道该怎么做。你有什么推荐的?
【问题讨论】: