如何从外部函数更改StatefulWidget类中的“状态”?
示例如下:
在 lib / main.dart
中import 'package:flutter/material.dart';
import 'increment-count.dart';
void main() => runApp(MyApp());
class MyApp extends StatelessWidget {
@override
Widget build(BuildContext context) {
return MaterialApp(
title: 'Flutter Demo',
theme: ThemeData(
primarySwatch: Colors.blue,
),
home: MyHomePage(title: 'Flutter Demo Home Page'),
);
}
}
class MyHomePage extends StatefulWidget {
MyHomePage({Key key, this.title}) : super(key: key);
final String title;
@override
_MyHomePageState createState() => _MyHomePageState();
}
class _MyHomePageState extends State<MyHomePage> {
int _counter = 0;
void _incrementCounter() {
setState(() {
_counter++;
});
}
@override
Widget build(BuildContext context) {
return Scaffold(
appBar: AppBar(
title: Text(widget.title),
),
body: Center(
child: Column(
mainAxisAlignment: MainAxisAlignment.center,
children: <Widget>[
Text(
'You have pushed the button this many times:',
),
Text(
'$_counter',
style: Theme.of(context).textTheme.display1,
),
],
),
),
floatingActionButton: FloatingActionButton(
onPressed: _incrementCounter,
tooltip: 'Increment',
child: Icon(Icons.add),
), // This trailing comma makes auto-formatting nicer for build methods.
);
}
}
我想将_incrementCounter函数移动到另一个文件。例如在'lib/increment-count.dart'
中。
在 /lib/increment-count.dart
中import 'package:flutter/material.dart';
void _incrementCounter() {
setState(() {
_counter++;
});
}
但是setState
会显示错误“未定义函数setState
” 。
有人可以帮忙吗?
答案 0 :(得分:3)
在此示例中,另一个文件中的移动功能没有意义,但这是解决方案。显然,对于要在其他地方重用的更大功能来说,这是一个好主意
在新文件increment-count.dart中添加此
int incrementCounter(int counter) {
return counter + 1;
}
然后在您的主类中调用它
onPressed: () => setState(() {
_counter = incrementCounter(_counter);
})
但是不可能回答您的问题,即如何通过外部函数设置状态。
答案 1 :(得分:1)
您收到此错误"The function setState isn't defined"
,因为第二个文件不是可以占用setState函数的有状态窗口小部件。如果要增加计数器,则无权访问,因为它被标记为私有,逻辑部分位于另一个文件中。
您需要的不是BloC模式或提供程序。由于我还是初学者,因此我建议您使用提供程序,因为它很容易学习,并且确实可以满足您的要求。
https://pub.dev/packages/provider
使用此功能,您可以像全局定义此功能并将其用于其他文件中。
例如,它看起来像这样(toggleCounter()
将成为全局函数):
final counterIncrement = Provider.of<Data>(context).toggleCounter();