list - flutter 开关按钮未更新

标签 list flutter dart button switch-statement

我是新手,过去几天一直在尝试制作待办事项 list 应用程序。我一直在尝试实现一项功能,用户可以将一项任务标记为重要任务,然后在列表 View 中突出显示该任务。但是,在我放置了“切换”按钮的页面中,切换后,即使后端功能正在运行并且任务被标记为重要,该按钮也不会更新。有人可以帮我吗?这是代码:-


class toDoList extends StatefulWidget
{
    bool data = false;
    @override
    createState() 
    {
        return new toDoListState();
    }
}

class toDoListState extends State<toDoList>
{
  List<String> tasks = [];
  List<String> completedTasks = [];
  List<String> descriptions = [];
  List<bool> importance = [];
  
    @override
    Widget build(BuildContext context)
    {
        return Scaffold
        (
            body: buildToDoList(),
            floatingActionButton: new FloatingActionButton
            (
                onPressed: addToDoItemScreen, 
                tooltip: 'Add Task',
                child: new Icon(Icons.add),
            ),
        );
    }

    Widget buildToDoList()
    {
        return new ListView.builder
        (
            itemBuilder: (context, index)
            {
                if(index < tasks.length)
                {
                    return row(tasks[index], descriptions[index], index);
                }
            },
        );
    }

    Widget row(String task, String description, int index)
    {                  
        return Dismissible(
        key: UniqueKey(),
        background: Container(color: Colors.red, child: Align(alignment: Alignment.center, child: Text('DELETE', textAlign: TextAlign.center, style: TextStyle(color: Colors.white, fontSize: 18),))),
        direction: DismissDirection.horizontal,
        onDismissed: (direction) {
        setState(() {
          tasks.removeAt(index);
          if(completedTasks.contains(task))
          {
              completedTasks.removeAt(index);
          }
          descriptions.removeAt(index);
          importance.removeAt(index);
        });
          Scaffold.of(context).showSnackBar(SnackBar(content: Text(task+" dismissed")));
        },
        child: CheckboxListTile(
          controlAffinity: ListTileControlAffinity.leading,
          title: Text(task, style: (completedTasks.contains(task)) ? TextStyle(decoration: TextDecoration.lineThrough) : TextStyle(),),
          subtitle: (importance[index]) ? Text('This is important') : Text('No it\'s not'),
          value: completedTasks.contains(task),
          onChanged: (bool value) {
           setState(() {
              if(!completedTasks.contains(task))
              {
                  completedTasks.add(task);
              }
              else
              {
                  completedTasks.remove(task);
              }
           });
          },
        ));
    }
  
  void addToDoItemScreen()
    {
      int index = tasks.length;
      while(importance.length > tasks.length)
      {
          importance.removeLast();   
      }
      importance.add(false);
      Navigator.of(context).push
      (
        new MaterialPageRoute(
         builder: (context) {
          return new Scaffold(
            appBar: new AppBar(
              title: new Text('Add a new task')
            ),
            body: Form
            (child: Column
            (
              children: <Widget>
              [TextField
              (
                autofocus: true,
                onSubmitted: (name) {
                  addToDoItem(name);
                  //Navigator.pop(context); // Close the add todo screen
              },
              decoration: new InputDecoration(
                hintText: 'Enter something to do...',
                contentPadding: const EdgeInsets.all(20.0),
                border: OutlineInputBorder()
              ),
             ),
             TextField
             (
               //autofocus: true,
               onSubmitted: (val)
               {
                  addDescription(val, index);
               },
               decoration: new InputDecoration(
                hintText: 'Enter a task decription...',
                contentPadding: const EdgeInsets.all(20.0),
                border: OutlineInputBorder()
              ),
             ),
             Center
             (
               child: Switch
               (
                  value: widget.data,
                  onChanged: (val)  
                  {
                    setState(() {
                      widget.data = val;
                      widget.data = !widget.data;
                      print(widget.data);
                    });
                    impTask(index);
                  },
               ),
             )
             ],
             ),)
             );
      }));
    }

    void addToDoItem(String task)
    {
        setState(() {
          tasks.add(task);
          descriptions.add("No description");
        });
    }

    void addDescription(String desc, int index)
    {
        setState(() {
          descriptions[index] = desc;
        });
    }

    void impTask(int index)
    {
        setState(() {
          if(importance[index])
          {
            importance[index] = false;
          }
          else 
          {
            importance[index] = true;
          }
        });
    }
}

最佳答案

StateFulBuilder添加到addToDoItemScreen()

  void addToDoItemScreen() {
    int index = tasks.length;
    while (importance.length > tasks.length) {
      importance.removeLast();
    }
    importance.add(false);
    Navigator.of(context).push(new MaterialPageRoute(builder: (context) {
      return StatefulBuilder(builder: (context, setState) { // this is new
        return new Scaffold(
            appBar: new AppBar(title: new Text('Add a new task')),
            body: Form(
              child: Column(
                children: <Widget>[
                  TextField(
                    autofocus: true,
                    onSubmitted: (name) {
                      addToDoItem(name);
                      //Navigator.pop(context); // Close the add todo screen
                    },
                    decoration: new InputDecoration(
                        hintText: 'Enter something to do...',
                        contentPadding: const EdgeInsets.all(20.0),
                        border: OutlineInputBorder()),
                  ),
                  TextField(
                    //autofocus: true,
                    onSubmitted: (val) {
                      addDescription(val, index);
                    },
                    decoration: new InputDecoration(
                        hintText: 'Enter a task decription...',
                        contentPadding: const EdgeInsets.all(20.0),
                        border: OutlineInputBorder()),
                  ),
                  Center(
                    child: Switch(
                      value: widget.data,
                      onChanged: (val) {
                        setState(() {
                          widget.data = val;
                        });
                        impTask(index);
                      },
                    ),
                  )
                ],
              ),
            ));
      });
    }));
  }

关于list - flutter 开关按钮未更新,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/63218567/

相关文章:

dart - 用dart解码JSON

dart - 使用三点 (...) 表示法在 Dart2 中添加条件映射条目有什么好处?

c# - FindBy 注释用于查找 WebElements 列表

python - 我的重新排列数组使得 arr[i] = i 的代码有什么问题?

c# - 在 CSV 文件中编写 C# 对象列表

android - 是否可以在 Flutter 中创建自定义快速设置磁贴?

list - 如何使用 Lisp 编写套套代码? (包括算法)

flutter - 如果计数值太大,该如何格式化?

dart - 向左或向右滑动以选择( flutter )

javascript - D3js/Javascript 与 Dart