zoukankan      html  css  js  c++  java
  • [Flutter] Creating, Importing & Using Dynamic Widgets from Other Files in a Flutter Application

    In this lesson we’ll learn how to import widgets we’ve created in other files & use them in our project. We'll also look at how to create dynamic properties in our widgets in order to make them reusable across our application.

    We have the CLI generate code:

    import 'package:flutter/material.dart';
    
    void main() => runApp(MyApp());
    
    class MyApp extends StatelessWidget {
      // This widget is the root of your application.
      @override
      Widget build(BuildContext context) {
        return MaterialApp(
          title: 'Flutter Demo',
          theme: ThemeData(
            // This is the theme of your application.
            //
            // Try running your application with "flutter run". You'll see the
            // application has a blue toolbar. Then, without quitting the app, try
            // changing the primarySwatch below to Colors.green and then invoke
            // "hot reload" (press "r" in the console where you ran "flutter run",
            // or simply save your changes to "hot reload" in a Flutter IDE).
            // Notice that the counter didn't reset back to zero; the application
            // is not restarted.
            brightness: Brightness.dark,
            primaryTextTheme: TextTheme(
              title: TextStyle(
                color: Colors.pinkAccent
              )
            ),
            primarySwatch: Colors.deepPurple,
            ),
          home: Scaffold(
            body: Center(
              child: Column(
                mainAxisAlignment: MainAxisAlignment.center,
                children: <Widget>[
                  Container(
                     300,
                    height: 300,
                    alignment: Alignment.center,
                    decoration: BoxDecoration(
                      color: Colors.black,
                      borderRadius: BorderRadius.circular(500)
                    ),
                    child: Text(
                      "Hello Flutter",
                      style: TextStyle(
                        color: Colors.red,
                        fontWeight: FontWeight.w500,
                        fontSize: 22.0
                      )
                    )
                  )
                ],
              )
            )
          ),
        );
      }
    }

    We want to replace the highlighted part with reusable Widget.

    import 'package:flutter/material.dart';
    
    class Greeting extends StatelessWidget {
      // To get passed in arg
      Greeting({
        @required this.greeting,
        this.color = Colors.green
      });
      // need to create a variable to hold greeting
      final String greeting;
      final Color color;
      @override
      Widget build(BuildContext context) {
        return Text(
          this.greeting,
          style: TextStyle(
            color: this.color,
            fontSize: 32
          )
        );
      }
    }

    Use it:

    import 'package:flutter/material.dart';
    import 'package:my_flutter_app/Greeting.dart';
    
    void main() => runApp(MyApp());
    
    class MyApp extends StatelessWidget {
      // This widget is the root of your application.
      @override
      Widget build(BuildContext context) {
        return MaterialApp(
          title: 'Flutter Demo',
          theme: ThemeData(
            // This is the theme of your application.
            //
            // Try running your application with "flutter run". You'll see the
            // application has a blue toolbar. Then, without quitting the app, try
            // changing the primarySwatch below to Colors.green and then invoke
            // "hot reload" (press "r" in the console where you ran "flutter run",
            // or simply save your changes to "hot reload" in a Flutter IDE).
            // Notice that the counter didn't reset back to zero; the application
            // is not restarted.
            brightness: Brightness.dark,
            primaryTextTheme: TextTheme(
              title: TextStyle(
                color: Colors.pinkAccent
              )
            ),
            primarySwatch: Colors.deepPurple,
            ),
          home: Scaffold(
            body: Center(
              child: Column(
                mainAxisAlignment: MainAxisAlignment.center,
                children: <Widget>[
                  Container(
                     300,
                    height: 300,
                    alignment: Alignment.center,
                    decoration: BoxDecoration(
                      color: Colors.black,
                      borderRadius: BorderRadius.circular(500)
                    ),
                    child: Greeting(greeting: "Hey you!", color: Colors.blue)
                  )
                ],
              )
            )
          ),
        );
      }
    }
  • 相关阅读:
    Mac 安装 Python3
    在push的时候发生崩溃信息
    Swift3.0 和 Swift3.0.2的区别
    01- 简单值
    @objc || private || 按钮的点击事件
    extension的作用
    swift3.0中使用代码添加选中图片
    OC-创建瀑布流
    springboot项目控制台日志不是彩色的原因
    更改docker里mysql的字符编码
  • 原文地址:https://www.cnblogs.com/Answer1215/p/10299612.html
Copyright © 2011-2022 走看看