首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >带有不匹配参数的闭包调用:函数“_TaskTileState.checkboxCallback”

带有不匹配参数的闭包调用:函数“_TaskTileState.checkboxCallback”
EN

Stack Overflow用户
提问于 2021-09-20 18:34:05
回答 1查看 95关注 0票数 0

--我的代码中出现了这个错误

代码语言:javascript
复制
======== Exception caught by widgets library =======================================================
The following NoSuchMethodError was thrown building TaskCheckbox(dirty):
Closure call with mismatched arguments: function '_TaskTileState.checkboxCallback'
Receiver: Closure: (bool) => void from Function 'checkboxCallback':.
Tried calling: _TaskTileState.checkboxCallback()
Found: _TaskTileState.checkboxCallback(bool) => void

The relevant error-causing widget was: 
  TaskCheckbox TaskCheckbox:file:///F:/Code/Flutter/todoey_flutter/lib/widgets/task_tile.dart:28:17
When the exception was thrown, this was the stack: 
#0      Object.noSuchMethod (dart:core-patch/object_patch.dart:63:5)
#1      _objectNoSuchMethod (dart:core-patch/object_patch.dart:106:9)

The relevant error-causing widget was: 
  TaskCheckbox TaskCheckbox:file:///F:/Code/Flutter/todoey_flutter/lib/widgets/task_tile.dart:28:17
When the exception was thrown, this was the stack: 
#0      Object.noSuchMethod (dart:core-patch/object_patch.dart:63:5)
#1      _objectNoSuchMethod (dart:core-patch/object_patch.dart:106:9)

这里是我的代码,通过这个错误

代码语言:javascript
复制
    // ignore_for_file: prefer_const_constructors

import 'package:flutter/material.dart';

class TaskTile extends StatefulWidget {
  @override
  State<TaskTile> createState() => _TaskTileState();
}

class _TaskTileState extends State<TaskTile> {
  bool isChecked = false;

  void checkboxCallback(bool checkboxState) {
    setState(() {
      isChecked = checkboxState;
    });
  }

  @override
  Widget build(BuildContext context) {
    return ListTile(
      title: Text(
        'This is task',
        style: TextStyle(
          decoration: isChecked ? TextDecoration.lineThrough : null,
        ),
      ),
      trailing: TaskCheckbox(isChecked, checkboxCallback),
    );
  }
}

class TaskCheckbox extends StatelessWidget {
  final bool checkboxState;
  final Function toggleCheckboxState;

  TaskCheckbox(this.checkboxState, this.toggleCheckboxState);

  @override
  Widget build(BuildContext context) {
    return Checkbox(
      activeColor: Colors.lightBlueAccent,
      value: checkboxState,
      onChanged: toggleCheckboxState(),
    );
  }
}

我正在尝试创建一个全局状态,以便在两个不同的类之间交换数据,并在屏幕上更改状态。

  • --这是一个任务管理应用程序,我在这里从静态变量中获取数据。我想在两个类之间交换布尔值,并根据这个布尔值显示任务列表。* this

可以有人帮我吗?

EN

回答 1

Stack Overflow用户

发布于 2022-04-17 18:06:26

代码语言:javascript
复制
import 'package:flutter/material.dart';

class TaskTile extends StatefulWidget {
  @override


 State<TaskTile>  createState() => _TaskTileState();
}
class _TaskTileState extends State<TaskTile> {
  bool isChecked=false;
      void CheckBoxCallback(bool? checkboxstate){
   setState(() {
     isChecked = checkboxstate!;
   });
  }

  @override
  Widget build(BuildContext context) {
    return ListTile(
      title:  Text('baking today',
      style: TextStyle(
          decoration: isChecked?TextDecoration.lineThrough:null),),
      trailing: TaskCheckBox(
        checkboxstate: isChecked,
        togglecheckboxstate: CheckBoxCallback,
        
      ),
    );
  }
}

class TaskCheckBox extends StatelessWidget {
  final bool checkboxstate;
  final Function(bool?)? togglecheckboxstate; // Here is where to make changes, observe the "bool?" i  added.
  TaskCheckBox({required this.checkboxstate,required this.togglecheckboxstate});

  @override
  Widget build(BuildContext context) {
    return Checkbox(
      value: checkboxstate,
      onChanged:togglecheckboxstate, // and here too on your code
    );
  }
}
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/69259318

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档