Warning: file_get_contents(/data/phpspider/zhask/data//catemap/8/logging/2.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
Flutter 如何更改';州';在StatefulWidget类中,但来自外部函数?_Flutter_Dart - Fatal编程技术网

Flutter 如何更改';州';在StatefulWidget类中,但来自外部函数?

Flutter 如何更改';州';在StatefulWidget类中,但来自外部函数?,flutter,dart,Flutter,Dart,如何从外部函数更改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) {

如何从外部函数更改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.
    );
  }
}
import 'package:flutter/material.dart';

void _incrementCounter() {
  setState(() {
    _counter++;
  });
}
但是
setState
显示错误“函数
setState
未定义”。
有人能帮忙吗?

您收到这个错误
“函数setState没有定义”
,因为第二个文件不是可以使用setState函数的有状态小部件。如果你想增加计数器,你没有访问权限,因为它被标记为私有,逻辑部分在另一个文件中

而不是集团模式或提供者是您所需要的。由于我还是初学者,我可以推荐您使用提供者,因为它非常容易学习,而且它完全符合您的需要

有了它,您可以全局定义这个函数,并在不同的文件中使用它

例如,它可以如下所示(
toggleCounter()
将是全局函数):

final counterIncrement=Provider.of(context.toggleCounter();

在本例中,在另一个文件中移动函数没有意义,但下面是解决方案。显然,这是一个伟大的想法,一个更大的功能,你想重用其他地方

在新文件increment-count.dart中添加以下内容

int incrementCounter(int counter) {
  return counter + 1;
}
然后在你的主课上打电话

 onPressed: () => setState(() {
      _counter = incrementCounter(_counter);
    })

但是,无法回答您的问题,即如何从外部函数设置状态。

为什么要将该函数移动到其他文件?也许您应该使用其他非设置状态的内容。你可以读到。还可以阅读@MidhunMP,我认为如果一个应用程序很大并且有很多函数,那么如果其中一些函数与父类分离,那么阅读起来就会更容易。
 onPressed: () => setState(() {
      _counter = incrementCounter(_counter);
    })