微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

有状态小部件中的 Flutter 字段不能是最终的

如何解决有状态小部件中的 Flutter 字段不能是最终的

Flutter 抱怨 _isSelected,因为它不是 final。问题是 must not 是最终的,因为它在 buttonpressed...

class SelectionButton extends StatefulWidget {
  final String title;
  final Function(String) onSelectionButtonTap;
  bool isSelected;

  SelectionButton({
    required this.title,required this.onSelectionButtonTap,required this.isSelected,});
  @override
  _SelectionButtonState createState() => _SelectionButtonState();
}

class _SelectionButtonState extends State<SelectionButton> {
  @override
  Widget build(BuildContext context) {
    return Expanded(
      child: GestureDetector(
        onTap: () {
          setState(() {
            widget.onSelectionButtonTap(widget.title);
            widget.isSelected = !widget.isSelected;
          });
        },child: Container(
          decoration: Boxdecoration(
            color: widget.isSelected ? AppColors.primary : AppColors.white,borderRadius: BorderRadius.circular(
              scaleWidth(10),),child: Center(
            child: Text(
              widget.title,textAlign: TextAlign.center,style: widget.isSelected
                  ? AppTextStyles.h5White
                  : AppTextStyles.h5Light,);
  }
}

这是 Flutter 给我的警告:

这个类(或这个类继承的一个类)被标记为“@immutable”,但它的一个或多个实例字段不是最终的:SelectionButton.isSelected

如您所见,我正在更改 widget.isSelected。我对颤振很陌生,不知道为什么颤振在这里抱怨。一切都按预期工作,但我想这不是最佳实践?我该如何解决这个问题?我在这里错过了什么?

解决方法

这是因为您应该在 State 类中操作 isSelected,而不是 StatefulWidget。您还希望在小部件上保留 Key 参数。将所有变量声明为 final 允许您将类声明为 const。

在 dart 中,const 意味着对象的整个深层状态可以在编译时完全确定,并且对象将被冻结并且完全不可变。

我们希望尽可能使用 const。

以下是重构小部件以关闭 Flutter 编译器的方法:

class SelectionButton extends StatefulWidget {
  final String title;
  final Function(String) onSelectionButtonTap;
  final bool isSelected;

  const SelectionButton({
    Key? key,required this.title,required this.onSelectionButtonTap,required this.isSelected,}) : super(key: key);

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

class _SelectionButtonState extends State<SelectionButton> {
  bool isSelected = false;

  @override
  void initState() {
    super.initState();
    isSelected = widget.isSelected;
  }

  @override
  Widget build(BuildContext context) {
    return Expanded(
      child: GestureDetector(
        onTap: () {
          setState(() {
            widget.onSelectionButtonTap(widget.title);
            isSelected = !isSelected;
          });
        },child: Container(
          decoration: BoxDecoration(
            color: isSelected ? AppColors.primary : AppColors.white,borderRadius: BorderRadius.circular(
              scaleWidth(10),),child: Center(
            child: Text(
              widget.title,textAlign: TextAlign.center,style: isSelected
                  ? AppTextStyles.h5White
                  : AppTextStyles.h5Light,);
  }
}

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。