Flutter有状态组件使用详解
更新时间:2022年01月16日 16:12:48 作者:s-010101
这篇文章主要为大家详细介绍了Flutter有状态组件的使用,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
有状态组件
flutter 主要有分有状态组件 StatefulWidget 和无状态组件 StatelessWidget,前面我们使用到的都是无状态组件,没有让页面上的内容发生变化,当我们有需要对页面的内容进行动态修改的时候 ,如果我们使用无状态组件,页面上的内容就不会被更新,这时需要用到有状态组件。
有状态组件就是继承了StatefulWidget的组件,内容更改时调用
setState(() { 更改的内容});
// ignore_for_file: prefer_const_constructors, prefer_collection_literals, deprecated_member_use, unused_local_variable, must_be_immutable, prefer_const_literals_to_create_immutables import 'package:flutter/material.dart'; void main() { runApp(MyApp()); } class MyApp extends StatelessWidget { const MyApp({Key? key}) : super(key: key); @override Widget build(BuildContext context) { return MaterialApp( home: Scaffold( appBar: AppBar( title: const Text('Flutter Demo'), ), body: const HomeContent(), ), theme: ThemeData( primarySwatch: Colors.yellow, ), ); } } //有状态自定义组件有两个类,我们需要返回的写在第二个类中 class HomeContent extends StatefulWidget { const HomeContent({Key? key}) : super(key: key); @override _HomeContentState createState() => _HomeContentState(); } class _HomeContentState extends State<HomeContent> { int count = 0; @override Widget build(BuildContext context) { return Center( child: Column( children: [ Chip( label: Text("$count"), ), ElevatedButton( onPressed: () { setState(() { count++; }); }, child: Text("点击加一")) ], ), ); } }
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持脚本之家。
相关文章
Android实现与Apache Tomcat服务器数据交互(MySql数据库)
本篇文章主要介绍了Android实现与Apache Tomcat服务器数据交互(MySql数据库),具有一定的参考价值,感兴趣的小伙伴们可以参考一下2017-06-06Android实现EditText控件禁止输入内容的方法(附测试demo)
这篇文章主要介绍了Android实现EditText控件禁止输入内容的方法,涉及Android针对EditText控件属性设置的相关技巧,需要的朋友可以参考下2015-12-12基于Android MarginLeft与MarginStart的区别(详解)
下面小编就为大家分享一篇基于Android MarginLeft与MarginStart的区别(详解),具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧2017-12-12
最新评论