写点什么

Flutter StatefulBuilder 示例

作者:坚果
  • 2022 年 5 月 17 日
  • 本文字数:3319 字

    阅读完需:约 11 分钟

本文是关于 Flutter 中的 StatefulBuilder 小部件。我们将介绍小部件的基础知识,然后检查一个在实际中使用它的完整示例。、StatefulBuilder 小部件可以在这些区域的状态发生变化时仅重建某些小区域而无需付出太多努力。这提高了应用程序的性能。


StatefulBuilder({  Key? key,   required StatefulWidgetBuilder builderr})
复制代码


builder 函数有两个参数:context 和一个用于在状态改变时触发重建的函数:


builder: (context, setInnerState) => SomeWidget(/* ...*/)
复制代码


另一个注意事项是,您应该将保持状态的变量保留在构建器函数之外。为了更清楚,请参阅下面的完整示例。

例子

预览

我们要构建的示例应用程序是一种计数器应用程序。它包含一个按钮和一个位于红色圆圈内的文本小部件。每按一次按钮,文本小部件中的数字就会增加一个单位。我们将只使用 StatefulBuilder 小部件来实现这一点。你不会看到任何 StatefulWidget


以下是它的工作原理:



**注意:**如果您使用的是 Safari,此演示视频可能无法正常播放或根本无法播放。请改用 Chrome、Edge、Firefox 或其他网络浏览器。

编码

带有解释的完整代码:


// main.dartimport 'package:flutter/material.dart';
void main() { runApp(const MyApp());}
class MyApp extends StatelessWidget { const MyApp({Key? key}) : super(key: key);
@override Widget build(BuildContext context) { return MaterialApp( // Remove the debug banner debugShowCheckedModeBanner: false, title: '大前端之旅', theme: ThemeData( primarySwatch: Colors.amber, ), home: const HomePage(), ); }}
// StatelessWidget is used hereclass HomePage extends StatelessWidget { const HomePage({Key? key}) : super(key: key);
@override Widget build(BuildContext context) { // This is the number shown in the red circle // It represents state and stays outside the builder function int count = 0; return Scaffold( appBar: AppBar(title: const Text('大前端之旅')), body: Padding( padding: const EdgeInsets.all(30), child: Center( // Implement StatefulBuilder child: StatefulBuilder( builder: (context, setInnerState) => Column( children: [ Container( width: 300, height: 300, decoration: const BoxDecoration( color: Colors.red, shape: BoxShape.circle), child: Center( // Display the number child: Text( count.toString(), style: const TextStyle(fontSize: 80, color: Colors.white), ), ), ), const SizedBox( height: 20, ), // This button is used to crease the number ElevatedButton.icon( onPressed: () { // Call setInnerState function setInnerState(() => count++); }, icon: const Icon(Icons.add), label: const Text('Increase By One')), ], ), ), ), ), ); }}
复制代码



举报此广告



本文是关于 Flutter 中的 StatefulBuilder 小部件。我们将介绍小部件的基础知识,然后检查一个在实际中使用它的完整示例。


目录


概述例子预览编码结论

概述

StatefulBuilder 小部件可以在这些区域的状态发生变化时仅重建某些小区域而无需付出太多努力。这提高了应用程序的性能。广告


StatefulBuilder({  Key? key,   required StatefulWidgetBuilder builderr})
复制代码


builder 函数有两个参数:context 和一个用于在状态改变时触发重建的函数:广告


builder: (context, setInnerState) => SomeWidget(/* ...*/)
复制代码


另一个注意事项是,您应该将保持状态的变量保留在构建器函数之外。为了更清楚,请参阅下面的完整示例。

例子

预览

我们要构建的示例应用程序是一种计数器应用程序。它包含一个按钮和一个位于红色圆圈内的文本小部件。每按一次按钮,文本小部件中的数字就会增加一个单位。我们将只使用 StatefulBuilder 小部件来实现这一点。你不会看到任何 StatefulWidget


以下是它的工作原理:


1.00


<video class="" autoplay="" controls="" loop="" muted="" data-lazy-type="video" data-src="https://www.kindacode.com/wp-content/uploads/2022/05/Flutter-StatefulBuilder.mp4" playsinline="" src="https://www.kindacode.com/wp-content/uploads/2022/05/Flutter-StatefulBuilder.mp4" style="margin: 0px; padding: 0px; box-sizing: border-box; width: 720px;"></video>


**注意:**如果您使用的是 Safari,此演示视频可能无法正常播放或根本无法播放。请改用 Chrome、Edge、Firefox 或其他网络浏览器。

编码

带有解释的完整代码:广告


// main.dartimport 'package:flutter/material.dart';
void main() { runApp(const MyApp());}
class MyApp extends StatelessWidget { const MyApp({Key? key}) : super(key: key);
@override Widget build(BuildContext context) { return MaterialApp( // Remove the debug banner debugShowCheckedModeBanner: false, title: 'KindaCode.com', theme: ThemeData( primarySwatch: Colors.amber, ), home: const HomePage(), ); }}
// StatelessWidget is used hereclass HomePage extends StatelessWidget { const HomePage({Key? key}) : super(key: key);
@override Widget build(BuildContext context) { // This is the number shown in the red circle // It represents state and stays outside the builder function int count = 0; return Scaffold( appBar: AppBar(title: const Text('KindaCode.com')), body: Padding( padding: const EdgeInsets.all(30), child: Center( // Implement StatefulBuilder child: StatefulBuilder( builder: (context, setInnerState) => Column( children: [ Container( width: 300, height: 300, decoration: const BoxDecoration( color: Colors.red, shape: BoxShape.circle), child: Center( // Display the number child: Text( count.toString(), style: const TextStyle(fontSize: 80, color: Colors.white), ), ), ), const SizedBox( height: 20, ), // This button is used to crease the number ElevatedButton.icon( onPressed: () { // Call setInnerState function setInnerState(() => count++); }, icon: const Icon(Icons.add), label: const Text('Increase By One')), ], ), ), ), ), ); }}
复制代码

结论

您已经了解了有关 StatefulBuilder 小部件的几乎所有内容。这在 Flutter 中并不是不可替代的东西,但在实现部分应用程序时会给你更多的选择。

发布于: 刚刚阅读数: 2
用户头像

坚果

关注

此间若无火炬,我便是唯一的光 2020.10.25 加入

公众号:“大前端之旅”,华为云享专家,InfoQ签约作者,51CTO博客首席体验官,专注于大前端技术的分享,包括Flutter,小程序,安卓,VUE,JavaScript。

评论

发布
暂无评论
Flutter StatefulBuilder 示例_5 月月更_坚果_InfoQ写作社区