flutter - 在构造函数中使用方法来初始化参数?

标签 flutter dart bloc

我想根据另一个参数的值在构造函数中初始化一个参数。

因此,根据 oldEmployee 是否不为空,我应将其添加到 availableEmployees 列表中,否则将availableEmployees列表保持原样。

我想在此类中执行此操作的原因是,我已阅读到,使用Bloc时,我应该在Bloc的状态内进行计算,而不是在UI中执行此操作。

这是我的类(class)样子:

class ShiftCreatedOrEdited extends ShiftsState {
  final List<Employee> availableEmployees;
  final Employee oldEmployee;

  const ShiftCreatedOrEdited({
    this.availableEmployees,
    this.oldEmployee,
  });

  List<Employee> addOldEmployeeToTheAvailableEmployees(List<Employee> availableEmployees, Employee oldEmployee) {
    if (oldEmployee != null) {
      List<Employee> hList = availableEmployees;
      hList.add(oldEmployee);
      return hList;
    } else {
      return availableEmployees;
    }
  }
}

最佳答案

这个怎么样:

void main() {}

class Employee {}

class ShiftsState {}

class ShiftCreatedOrEdited {
  final Employee oldEmployee;
  final List<Employee> availableEmployees;

  ShiftCreatedOrEdited(
      Employee _oldEmployee, List<Employee> _availableEmployees)
      : this.availableEmployees =
            _availableEmployees + (_oldEmployee != null ? [_oldEmployee] : []),
        this.oldEmployee = _oldEmployee;
}

关于flutter - 在构造函数中使用方法来初始化参数?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/61956400/

相关文章:

flutter - Mockito 重置通话计数?

flutter - 在 flutter 行/列中独立对齐元素

flutter - Instagram "heart-ing"帖子平滑 api 调用背后的逻辑

flutter - 初始化时对ListView中的元素进行动画处理

flutter - 错误 : The method 'ancestorStateOfType' isn't defined for the class 'BuildContext'

flutter - 使用不包含 Bloc 类型的上下文调用的 BlocProvider.of()

Flutter:如何在没有后退按钮的情况下推送导航路线?

image - 如何在我的 flutter 应用程序中从 bing web search apiv7 获取图像

image - 将图像堆叠在两个小部件中( flutter )

dart - flutter 波纹效果颜色