如何使用复选框使用 array/list 更改 fluter/dart 中的文本(onchanged/setstate 有问题)

How to use a Checkbox to change text in fluter/dart using an array/list (troubles with onchanged/setstate)

在此先感谢,我对此还很陌生,已经学习了一些教程并在这里阅读了无数帖子。

我正在做一个个人项目,但遇到了死胡同。

我希望通过使用复选框来更改文本小部件中的文本,实质上是将其打开和关闭。 不幸的是,最初看起来很简单的事情在过去一周左右让我发疯了,如果这个问题得到了回答,我深表歉意,但我找不到我需要的帮助,我发现了类似的事情,但到目前为止没有任何效果。

我正在尝试使用 onchanged 更改我的 int 值,并使用 list/array 和 int 值设置 stafe 函数,我实际上想将值从 0 设置为 1 然后再返回。

var textChange = [" could be ", " have become "];
int t = 0;

与;

onChanged: (value) {
                setState(() {
                  boxChecked = value!;
                  if (boxChecked) {
                    t = 1;
                  } else if (!boxChecked){
                    t = 0;
                  }
                  }
                );
              },

我已经确定我正在扩展一个有状态的小部件尝试设置不同的功能和方法来传递,我已经尝试使用 material 按钮而不是复选框但仍然遇到同样的问题。 我尝试了几种不同的方法来编写我的起始函数,包括像 [t++ 或 t = (d + 1) % textChange.length;] 这样简单的方法,但是一旦 int =>2,这些最终会以错误结束,但是我什至无法改变我的 int 值。 如果我手动更改它并 运行 程序,它就可以工作。但是我似乎无法更改并设置状态代码来影响我的数组或整数。 我什至将我的原始数组作为 List,将其更改为 var,希望它能使其可变。

我希望我说的是对的,我显然遗漏了一些东西,但我看了这么多我只是失去了。

下面是我使用的代码,其中包含从我的项目的其余部分中删除的代码。我正在使用 android 个具有最新更新的工作室。

感谢您的帮助和时间。

import 'package:flutter/material.dart';

void main() {
  runApp(MyApp());
}

class MyApp extends StatelessWidget {
  // This widget is the root of your application.
  @override
  Widget build(BuildContext context) {
    return MaterialApp(
      title: 'alternate text code',
      theme: ThemeData(
        primarySwatch: Colors.blue,
      ),
      home: MyHomePage(title: 'alternate text'),
    );
  }
}

class MyHomePage extends StatefulWidget {
  MyHomePage({Key? key, required this.title}) : super(key: key);


  final String title;

  @override
  _MyHomePageState createState() => _MyHomePageState();
}

class _MyHomePageState extends State<MyHomePage> {

  Widget build(BuildContext context) {
    return Scaffold(
      appBar: AppBar(
        title: Text(widget.title),
      ),
      body: Center(
        child: Column(
          mainAxisAlignment: MainAxisAlignment.center,
          children: <Widget>[
            Divider(),
            Container(
              width: MediaQuery.of(context).size.width / 1.2,
              child:
              Text(
                'I am having trouble getting some code to work, i have tried '
                'a lot of things but cant work it out.'
                'I would like the check box to change the line of text below',
              ),
            ),
            Divider(),
            Container(
              width: MediaQuery.of(context).size.width / 1.2,
              child:
                ChangeText(),
            ),
            Divider(),
            Container(
              width: MediaQuery.of(context).size.width / 1.2,
              child:
              Text(
                'you' + textChange[t] + 'a App Developer.',
              ),
            ),
          ],
        ),
      ),
    );
  }
}

bool boxChecked = false;

class ChangeText extends StatefulWidget {
  const ChangeText({Key? key}) : super(key: key);

  @override
  State<ChangeText> createState() => _ChangeText();
}

var textChange = [" could be ", " have become "];
int t = 0;

class _ChangeText extends State<ChangeText> {
  @override
  Widget build(BuildContext context) {
    return Expanded(
      child:
      Container(
            child: CheckboxListTile(
              title: const Text('learn Flutter', style: TextStyle(fontSize: 14),),
              value: boxChecked,
              onChanged: (value) {
                setState(() {
                  boxChecked = value!;
                  if (boxChecked) {
                    t = 1;
                  } else if (!boxChecked){
                    t = 0;
                  }
                  }
                );
              },
            ),
      ),
    );
  }
}

ChangeText 小部件调用 setState 意味着它只会更改 ChangeText 小部件中的 UI。但是,文本反映需要发生在 MyHomePage。您可以使用全局键更改父状态或仅使用回调方法

class ChangeText extends StatefulWidget {
  final Function callBack;
  const ChangeText({
    Key? key,
    required this.callBack,
  }) : super(key: key);

........
    onChanged: (value) {
          setState(() {
            boxChecked = value!;
            if (boxChecked) {
              t = 1;
            } else if (!boxChecked) {
              t = 0;
            }
          });
          widget.callBack();
        },

并使用类似

              child: ChangeText(
                callBack: () {
                  setState(() {});
                },
              ),

完整小部件


void main() {
  runApp(MyApp());
}

class MyApp extends StatelessWidget {
  // This widget is the root of your application.
  @override
  Widget build(BuildContext context) {
    return MaterialApp(
      title: 'alternate text code',
      theme: ThemeData(
        primarySwatch: Colors.blue,
      ),
      home: MyHomePage(title: 'alternate text'),
    );
  }
}

class MyHomePage extends StatefulWidget {
  MyHomePage({Key? key, required this.title}) : super(key: key);

  final String title;

  @override
  _MyHomePageState createState() => _MyHomePageState();
}

class _MyHomePageState extends State<MyHomePage> {
  Widget build(BuildContext context) {
    return Scaffold(
      appBar: AppBar(
        title: Text(widget.title),
      ),
      body: Center(
        child: Column(
          mainAxisAlignment: MainAxisAlignment.center,
          children: <Widget>[
            Divider(),
            Container(
              width: MediaQuery.of(context).size.width / 1.2,
              child: Text(
                'I am having trouble getting some code to work, i have tried '
                'a lot of things but cant work it out.'
                'I would like the check box to change the line of text below',
              ),
            ),
            Divider(),
            Container(
              width: MediaQuery.of(context).size.width / 1.2,
              child: ChangeText(
                callBack: () {
                  setState(() {});
                },
              ),
            ),
            Divider(),
            Container(
              width: MediaQuery.of(context).size.width / 1.2,
              child: Text(
                'you' + textChange[t] + 'a App Developer.',
              ),
            ),
          ],
        ),
      ),
    );
  }
}

bool boxChecked = false;

class ChangeText extends StatefulWidget {
  final Function callBack;
  const ChangeText({
    Key? key,
    required this.callBack,
  }) : super(key: key);

  @override
  State<ChangeText> createState() => _ChangeText();
}

var textChange = [" could be ", " have become "];
int t = 0;

class _ChangeText extends State<ChangeText> {
  @override
  Widget build(BuildContext context) {
    return
        // Expanded(
        //   child:

        Container(
      child: CheckboxListTile(
        title: const Text(
          'learn Flutter',
          style: TextStyle(fontSize: 14),
        ),
        value: boxChecked,
        onChanged: (value) {
          setState(() {
            boxChecked = value!;
            if (boxChecked) {
              t = 1;
            } else if (!boxChecked) {
              t = 0;
            }
          });
          widget.callBack();
        },
      ),
      // ),
    );
  }
}