首页 > 其他分享 >一统天下 flutter - widget Builder: StatefulBuilder - 有状态的 Builder

一统天下 flutter - widget Builder: StatefulBuilder - 有状态的 Builder

时间:2023-03-22 11:03:56浏览次数:46  
标签:widget builder counter flutter 一统天下 StatefulBuilder Builder

一统天下 flutter https://github.com/webabcd/flutter_demo
作者 webabcd

一统天下 flutter - widget Builder: StatefulBuilder - 有状态的 Builder

示例如下:

lib\widget\builder\stateful_builder.dart

/*
 * StatefulBuilder - 有状态的 Builder
 *
 * 请先了解 Builder,参见 builder.dart
 */

import 'package:flutter/material.dart';

import '../../helper.dart';

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

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

class _StatefulBuilderDemoState extends State<StatefulBuilderDemo> {
  @override
  Widget build(BuildContext context) {
    int counter = 0;
    return Column(
      mainAxisAlignment: MainAxisAlignment.center,
      children: [
        MyText('counter: $counter'),
        Builder(
          builder: (BuildContext context) {
            /// 相对于 Builder 来说,StatefulBuilder 会多出一个 StateSetter 类型的对象
            return StatefulBuilder(
                builder: (BuildContext context, StateSetter setState) {
                  return TextButton(
                      onPressed: () {
                        /// 可以通过 StateSetter 对象修改状态,其会让对应的 StatefulBuilder 重绘,而 StatefulBuilder 之外的部分不会重绘
                        setState(() => { counter++ });
                      },
                      child: Text('counter: $counter')
                  );
                }
            );
          },
        ),
      ],
    );
  }
}

一统天下 flutter https://github.com/webabcd/flutter_demo
作者 webabcd

标签:widget,builder,counter,flutter,一统天下,StatefulBuilder,Builder
From: https://www.cnblogs.com/webabcd/p/flutter_lib_widget_builder_stateful_builder.html

相关文章