GetX -从Get.Dialog返回值

  1. GetMaterialApp

在main.dart中,确保MyApp返回的是GetMaterialApp而不是MaterialApp

class MyApp extends StatelessWidget {

// This widget is the root of your application.

@override

Widget build(BuildContext context) {

return GetMaterialApp( // <-- Use GetMaterialApp

title: 'Flutter Demo',

home: MyHomePage(title: 'Flutter Examples'),

);

}

}

这允许Get处理导航/路由,使导航方法可用,例如:Get.to()、Get.dialog()、Get.back()等。如果没有GetMaterialApp作为应用程序的根,当调用任何导航方法时,您将看到一个(令人困惑的)错误:

E/flutter (11139): [ERROR:flutter/lib/ui/ui_dart_state.cc(166)] Unhandled Exception:

'package:flutter/src/widgets/localizations.dart': Failed assertion:

line 453 pos 12: 'context != null': is not true.

复制

  1. Get.dialog +Get.back(结果: X)

让你对Get.dialog的调用期望一个异步返回值...

onPressed: () async {

// assign return value to an observable

return lx.result.value = await Get.dialog(

...。在使用Get.back(result: X)关闭对话框时返回,其中X是通过Get.dialog返回的动态值

onPressed: () => Get.back(result: true),

复制

完整示例:

dart 复制代码
import 'package:flutter/material.dart';
import 'package:get/get.dart';

class LoginX extends GetxController {
  RxBool result = false.obs;
}

class GetDialogReturnPage extends StatelessWidget {
  final LoginX lx = Get.put(LoginX());

  @override
  Widget build(BuildContext context) {
    return Scaffold(
      appBar: AppBar(
        title: Text('GetDialog Return Example'),
      ),
      body: SafeArea(
        child: Column(
          crossAxisAlignment: CrossAxisAlignment.center,
          mainAxisAlignment: MainAxisAlignment.spaceEvenly,
          children: [
            Container(
              child: Obx(() => Text('Value shows here: ${lx.result.value}')),
            ),
            Container(
              alignment: Alignment.center,
              child: RaisedButton(
                child: Text('Login'),
                onPressed: () async {
                  // ** assign return value to an observable **
                  return lx.result.value = await Get.dialog(
                      AlertDialog(
                          content: Row(
                            mainAxisAlignment: MainAxisAlignment.spaceEvenly,
                            children: [
                              RaisedButton(
                                child: Text('Good Login'),
                                onPressed: () => Get.back(result: true),
                                // ** result: returns this value up the call stack **
                              ),
                              SizedBox(width: 5,),
                              RaisedButton(
                                child: Text('Bad Login'),
                                onPressed: () => Get.back(result: false),
                              ),
                            ],
                          )
                      )
                  );},
              ),
            )
          ],
        ),
      ),
    );
  }
}

我的例子参考:

dart 复制代码
  Future<bool?> showRemoveDialog(

      String title, String content, bool showCheckbox) async {

      debugPrint(title);

      return await Get.defaultDialog(
        title: title,
        content: Text(content),
        onConfirm: ()=>Get.back(result: true),
        onCancel: ()=>Get.back(result: false),
      );
    }
相关推荐
前端付豪1 小时前
1、震惊!99% 前端都没搞懂的 JavaScript 类型细节
前端·javascript·面试
朝与暮1 小时前
js符号(Symbol)
前端·javascript
大怪v2 小时前
前端:人工智能?我也会啊!来个花活,😎😎😎“自动驾驶”整起!
前端·javascript·算法
CYRUS_STUDIO2 小时前
用 Frida 控制 Android 线程:kill 命令、挂起与恢复全解析
android·linux·逆向
CYRUS_STUDIO2 小时前
Frida 实战:Android JNI 数组 (jobjectArray) 操作全流程解析
android·逆向
遂心_4 小时前
为什么 '1'.toString() 可以调用?深入理解 JavaScript 包装对象机制
前端·javascript
王同学QaQ4 小时前
Vue3对接UE,通过MQTT完成通讯
javascript·vue.js
程序员鱼皮5 小时前
刚刚 Java 25 炸裂发布!让 Java 再次伟大
java·javascript·计算机·程序员·编程·开发·代码
Asort5 小时前
JavaScript 从零开始(五):运算符和表达式——从零开始掌握算术、比较与逻辑运算
前端·javascript
一枚前端小能手5 小时前
🚀 缓存用错了网站更慢?前端缓存策略的5个致命误区
前端·javascript