簡體   English   中英

如何從外部 function 更改 StatefulWidget class 中的“狀態”?

[英]How do I change the 'state' in a StatefulWidget class but from an external function?

如何從外部 function 更改 StatefulWidget class 中的“狀態”?

示例如下:

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 function 移動到另一個文件。 例如在'lib/increment-count.dart'中。

/lib/increment-count.dart

import 'package:flutter/material.dart';

void _incrementCounter() {
  setState(() {
    _counter++;
  });
}

setState反而顯示錯誤"The function setState is not defined" 誰能幫忙?

在此示例中將 function 移動到另一個文件中沒有意義,但這是解決方案。 顯然,對於您想在其他地方重用的更大的 function 來說這是一個好主意

在你的新文件中 increment-count.dart 添加這個

int incrementCounter(int counter) {
  return counter + 1;
}

然后在你的主 class 中調用它

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

但是回答您的問題,如何從外部 function 設置狀態是不可能的。

您收到此錯誤"The function setState isn't defined" ,因為第二個文件不是可以占用 setState function 的有狀態小部件。 如果你想增加你無權訪問的計數器,因為它被標記為私有並且邏輯部分在不同的文件中。

比 BloC 模式或提供者是您所需要的。 由於我還是初學者,我可以推薦您使用提供程序,因為它很容易學習,並且完全符合您的要求。

https://pub.dev/packages/provider

有了這個,你可以像全局定義這個 function 並在不同的文件中使用它。

例如,這可能看起來像這樣( toggleCounter()將是全局 function 然后):

final counterIncrement = Provider.of<Data>(context).toggleCounter();

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM