关于flutter:在-Flutter-使用-GetX-对话框

55次阅读

共计 5172 个字符,预计需要花费 13 分钟才能阅读完成。

在 Flutter 应用 GetX 对话框

原文

https://medium.flutterdevs.co…

参考

  • https://pub.dev/packages/get

注释

理解如何在您的 Flutter 应用程序应用 GetX 创立一个对话框

在 Flutter 应用 GetX 对话框

是挪动应用程序的根本组成部分。他们帮忙传递正告和重要信息,以及做具体的流动。当 Flutter 开发人员在 Flutter 制作一个对话框时,它利用上下文和生成器制作一个对话框。然而,对于开发人员来说,利用上下文和构建器来造就 Dialogs 是不适合的。

在本文中,咱们将摸索在 Flutter 应用 GetX 的对话框。咱们还将实现一个演示程序,并理解如何应用您的 Flutter 应用程序的获取包创立对话框。

获取 | Flutter Package

GetX 是一个超轻和弱小的解决方案 Flutter。它联合了高性能的状态治理,智能..

https://pub.dev/packages/get

Introduction:

简介:

当咱们须要显示任何相似表单的内容时,咱们能够创立这个对话框,它波及 Flutter 的 GetX 库。咱们能够使对话框利用 GetX 的根本代码和非常简单的使一个对话框。它没有利用上下文和生成器来创立对话框。

是 Flutter 问题的附加轻量强解。它退出了精英的性能状态治理、智能依赖注入治理和路由治理。

演示模块:

这个演示视频展现了如何在 Flutter 中创立一个对话框,并展现了如何应用您的 Flutter 应用程序中的 get 包来工作,以及应用不同的属性。它会显示在你的设施上。

Constructor:

要应用 Get.defaultDialog (),须要调用上面的构造函数:

Future<T?> defaultDialog<T>({
  String title = "Alert",
  EdgeInsetsGeometry? titlePadding,
  TextStyle? titleStyle,
  Widget? content,
  EdgeInsetsGeometry? contentPadding,
  VoidCallback? onConfirm,
  VoidCallback? onCancel,
  VoidCallback? onCustom,
  Color? cancelTextColor,
  Color? confirmTextColor,
  String? textConfirm,
  String? textCancel,
  String? textCustom,
  Widget? confirm,
  Widget? cancel,
  Widget? custom,
  Color? backgroundColor,
  bool barrierDismissible = true,
  Color? buttonColor,
  String middleText = "Dialog made in 3 lines of code",
  TextStyle? middleTextStyle,
  double radius = 20.0,
  List<Widget>? actions,
  WillPopCallback? onWillPop,
  GlobalKey<NavigatorState>? navigatorKey,
})

Properties:

有一些 Get.defaultDialog () 的属性:

  • > title: 此属性用于对话框的题目。默认状况下,题目为“Alert”。
  • > titleStyle: 此属性用于应用 TextStyle 给题目文本赋予的款式。
  • > content: 在这个属性中用于给出对话框的内容,并且应该应用 Widget 给出内容。
  • > middleText: 此属性用于对话框的两头文本。如果咱们也利用内容,那么内容小部件数据将被收获。
  • > barrierDismissible: 如果咱们想通过单击对话框内部来敞开对话框,那么这个属性的值应该为 true else false。默认状况下,它的值为 true。
  • > middleTextStyle: 此属性用于应用 TextStyle 给两头文本赋予的款式。
  • > radius: 在此属性中应用的是提供的对话框的半径。默认状况下,它的值为 20。
  • > backgroundColor: 在这个属性中用作对话框的背景色彩。

Implementation:

  • 第一步: 增加依赖项

将依赖项增加到 pubspec ー yaml 文件。

dependencies:
  flutter:
    sdk: flutter
  get: ^4.6.1
  • 第二步: 导入
import 'package:get/get.dart';
  • 第三步: 在应用程序的根目录中运行 flutter 软件包。

如何实现 dart 文件中的代码:

你须要别离在你的代码中实现它:

在 lib 文件夹中创立一个名为 main.dart 的新 dart 文件。

咱们应用了 GetMaterialApp 而不是 MaterialApp,因为咱们正在应用 GetX 库构建应用程序。如果咱们不利用 GetMaterialApp,那么,在这一点上,它的性能将不工作。

return GetMaterialApp(
  title: 'Dialog Demo',
  theme: ThemeData(primarySwatch: Colors._blue_,),
  home: Splash(),
  debugShowCheckedModeBanner: false,
);

咱们将在 main.dart 文件中创立一个 Home 类

在注释中,咱们将增加一个 Center 小部件。在这个小部件中,咱们将增加一个 Column 小部件,该小部件的核心是 mainAxisAlignment。咱们将增加一些货色,首先,咱们将增加一个图像,其次,咱们将增加一个带有子属性和款式属性的立面按钮。在 onPressed 函数中,咱们将增加 Get.defaultDialog ()。咱们将在上面深刻形容它。

Center(
    child: Column(
      mainAxisAlignment: MainAxisAlignment.center,
      children: [Image.asset("assets/logo.png", scale: 14,),
        SizedBox(height: 80,),
        ElevatedButton(child: Text('Show Dialog'),
          style: ElevatedButton._styleFrom_(
            primary: Colors._teal_,
            onPrimary: Colors._white_,
            shadowColor: Colors._tealAccent_,
            textStyle: TextStyle(fontSize: 18,),
            elevation: 5,
            shape: RoundedRectangleBorder(borderRadius: BorderRadius.circular(20.0)),
            minimumSize: Size(120, 50),
          ),
          onPressed: () {Get.defaultDialog(); },
        ),
      ],
    )),

当咱们运行应用程序时,咱们应该失去屏幕的输入,就像上面的屏幕截图一样。

Home Screen 主屏幕

当初,咱们将深刻形容 Get.defaultDialog () :

当初您看到了在 Flutter 应用 GetX 取得只有很少行的对话是如许容易。您还能够应用 GetX 提供的不同选项对其进行自定义。咱们将增加题目,两头文本,背景色彩,题目款式,两头文本款式和半径。

Get.defaultDialog(
  title: "Welcome to Flutter Dev'S",
  middleText: "FlutterDevs is a protruding flutter app development company with"
      "an extensive in-house team of 30+ seasoned professionals who know"
      "exactly what you need to strengthen your business across various dimensions",
  backgroundColor: Colors._teal_,
  titleStyle: TextStyle(color: Colors._white_),
  middleTextStyle: TextStyle(color: Colors._white_),
  radius: 30
);

当咱们运行应用程序时,咱们应该失去屏幕的输入,就像上面的屏幕截图一样。

Final Output 最终输入

全副代码:

import 'package:flutter/material.dart';
import 'package:flutter_dialog_getx_demo/splash_screen.dart';
import 'package:get/get.dart';

void main() {runApp(MyApp());
}

class MyApp extends StatelessWidget {
  // This widget is the root of your application.
  @override
  Widget build(BuildContext context) {
    return GetMaterialApp(
      title: 'Dialog Demo',
      theme: ThemeData(primarySwatch: Colors._blue_,),
      home: Splash(),
      debugShowCheckedModeBanner: false,
    );
  }
}

class Home extends StatelessWidget {
  @override
  Widget build(BuildContext context) {
    return Scaffold(
      appBar: AppBar(
        automaticallyImplyLeading: false,
        title: Text('Dialog Using GetX In Flutter'),
        centerTitle: true,
        backgroundColor: Colors._cyan_,
      ),
      body: Center(
          child: Column(
            mainAxisAlignment: MainAxisAlignment.center,
            children: [Image.asset("assets/logo.png", scale: 14,),
              SizedBox(height: 80,),
              ElevatedButton(child: Text('Show Dialog'),
                style: ElevatedButton._styleFrom_(
                  primary: Colors._teal_,
                  onPrimary: Colors._white_,
                  shadowColor: Colors._tealAccent_,
                  textStyle: TextStyle(fontSize: 18,),
                  elevation: 5,
                  shape: RoundedRectangleBorder(borderRadius: BorderRadius.circular(20.0)),
                  minimumSize: Size(120, 50),
                ),
                onPressed: () {
                  Get.defaultDialog(
                    title: "Welcome to Flutter Dev'S",
                    middleText: "FlutterDevs is a protruding flutter app development company with"
                        "an extensive in-house team of 30+ seasoned professionals who know"
                        "exactly what you need to strengthen your business across various dimensions",
                    backgroundColor: Colors._teal_,
                    titleStyle: TextStyle(color: Colors._white_),
                    middleTextStyle: TextStyle(color: Colors._white_),
                    radius: 30
                  );
                },
              ),
            ],
          )),
    );
  }
}

结语:

在本文中,我曾经解释了应用 GetX 的对话框的根本构造; 您能够依据本人的抉择批改这段代码。这是我对应用 GetX 进行用户交互的对话框的一个小小介绍,它正在应用 Flutter 工作。

我心愿这个博客将提供您充沛的信息,尝试在您的 Flutter 我的项目应用 GetX 对话框。咱们将向您展现介绍是什么?. 应用 GetX 插件制作一个工作对话框的演示程序。在本博客中,咱们曾经钻研了 flutter 应用程序的应用 GetX 的对话框。我心愿这个博客能帮忙你更好地了解这个对话框。所以请尝试一下。


© 猫哥

  • 微信 ducafecat
  • 博客 ducafecat.tech
  • github
  • bilibili

正文完
 0