Flutter   发布时间:2022-05-03  发布网站:大佬教程  code.js-code.com
大佬教程收集整理的这篇文章主要介绍了mobile – Flutter – 单击时渲染新的小部件大佬教程大佬觉得挺不错的,现在分享给大家,也给大家做个参考。
标题基本上都说明了一切.一个非常高兴的问题……我有这个基本代码来创建我的应用程序的初始状态:

class MyApp extends StatelessWidget {
  @override
  Widget build(BuildContext context) {
    return new MaterialApp(
      title: 'Flutter Demo',theme: new ThemeData(
        priMarySwatch: Colors.blue,),home: new MyHomePage(title: 'Some title'),);
  }
}

class MyHomePage extends StatefulWidget {
  MyHomePage({Key key,this.titlE}) : super(key: key);

  final String title;

  @override
  _MyHomePageState createState() => new _MyHomePageState();
}

class _MyHomePageState extends State<MyHomePage> {

  @override
  Widget build(BuildContext context) {

    return new Scaffold(
      appBar: new AppBar(title: new Text(config.titlE)),body: new column(
        mainAxisAlignment: MainAxisAlignment.spaceEvenly,children: [
          new InputWidget(),]
      ),);
  }
}

现在,当用户点击按钮时,如何呈现新的Widget?假设我想实例化另一个InputWidget.

谢谢

解决方法

我希望我能正确理解你的问题……

我认为主要的一点是你不应该想到“另一个”小部件 – 如果你改变MyHomePage的内容从拥有第一个孩子然后两个你没有真正保留第一个孩子然后再添加一个孩子.你只是先说“我想要一个孩子”然后你改变主意并说“我想要两个孩子”.

在您的代码中,您可以通过在_MyHomePageState中调用setState来完成此操作. Flutter负责保留第一个添加第二个孩子.

import 'dart:core';
import 'package:Flutter/material.dart';

class MyApp extends StatelessWidget {
  @override
  Widget build(BuildContext context) {
    return new MaterialApp(
      title: 'Flutter Demo',this.titlE}) : super(key: key);

  final String title;

  @override
  _MyHomePageState createState() => new _MyHomePageState();
}

class _MyHomePageState extends State<MyHomePage> {

  @R_450_3867@ = 1;

  @override
  Widget build(BuildContext context) {
    List<Widget> children = new List.generate(count,(int i) => new InputWidget(i));

    return new Scaffold(
        appBar: new AppBar(title: new Text(widget.titlE)),body: new column(
            mainAxisAlignment: MainAxisAlignment.spaceEvenly,children: children
        ),floaTingActionButton: new FloaTingActionButton(
          child: new Icon(Icons.add),onPressed: () {
            setState(() {
              count = count + 1;
            });
          },)
    );
  }
}

class InputWidget extends StatelessWidget {

  final int index;

  InputWidget(this.indeX);

  @override
  Widget build(BuildContext context) {
    return new Text("InputWidget: " + index.toString());
  }
}

这是你的意思吗?

大佬总结

以上是大佬教程为你收集整理的mobile – Flutter – 单击时渲染新的小部件全部内容,希望文章能够帮你解决mobile – Flutter – 单击时渲染新的小部件所遇到的程序开发问题。

如果觉得大佬教程网站内容还不错,欢迎将大佬教程推荐给程序员好友。

本图文内容来源于网友网络收集整理提供,作为学习参考使用,版权属于原作者。
如您有任何意见或建议可联系处理。小编QQ:384754419,请注明来意。