热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

出色的对话框未在Flutter应用中关闭

我在flutter应用程序中使用了Awesom

我在flutter应用程序中使用了Awesome Dialog,但是当我单击OK时,它只是导航到另一个屏幕而没有关闭。
这是我的代码。

Future requestSupport(String userid,String supportType,String duration) async {
final respOnse=
await http.post('http://url/api/Support',headers: {"Content-Type": "application/json",'accept': 'application/json',},body: json.encode({'userid' : userid,'supportType' : supportType,'duration' : duration}));
if (response.statusCode == 200) {
showAlertDialogOnOkCallback();
}
}
void showAlertDialogOnOkCallback() {
AwesomeDialog(
context: context,animType: AnimType.LEFTSLIDE,dialogType: DialogType.SUCCES,tittle: 'Success',desc:
'You have been entered into the queue,press OK to go back.',btnOkOnPress: () { },btnOkIcon: Icons.check_circle,onDissmissCallback: () {
debugPrint('Dialog Dissmiss from callback');
}).show();
}
}


尽管该图书馆的doc说,


  

处理正按钮单击,关闭对话框的功能在内部处理。



更新:我自己尝试过,并且使用的方法很好,
我按下了按钮以打开对话框,

RaisedButton(
child: Text("ok",),onPressed: () {
open();
},

由于默认情况下我使用Navigator.pop(context);的库来关闭对话框,因此使用btnOkOnPress返回到上一个屏幕

void open() {
AwesomeDialog(
context: context,dialogType: DialogType.INFO,animType: AnimType.BOTTOMSLIDE,tittle: 'Dialog Title',desc:
'Dialog description here',btnCancelOnPress: () {},btnOkOnPress: () {
Navigator.pop(context);
}).show();
}

注意:我导航到屏幕,该屏幕上有Navigator.pushNamed的对话框。因此,如果调用Navigator.pop(context);,则仅返回此屏幕。

Navigator.pushNamed(context,RouteName.ReportScreen);

输出:

enter image description here

,

我无法复制您的问题。我在点击RaisedButton时使用了一个简单的AwesomeDialog。然后点击对话框的OK按钮将其正确关闭。我还通过在单击确定按钮时添加导航功能进行了测试,该功能可以关闭对话框并导航至下一个屏幕。我使用的代码:

body: Center(
child: RaisedButton(
onPressed: () {
_openDialog();
},child: Text('Tap')
)
)
void _openDialog() {
AwesomeDialog(
context: context,animType: AnimType.LEFTSLIDE,dialogType: DialogType.SUCCES,tittle: 'Success',desc:
'You have been entered into the queue,press OK to go back.',btnOkOnPress: () {
Navigator.push(context,MaterialPageRoute(builder: (context) => PageB()));
},btnOkIcon: Icons.check_circle,onDissmissCallback: () {
debugPrint('Dialog Dissmiss from callback');
}).show();
}

控制台输出:

I/flutter (13279): Dialog Dissmiss from callback
I/flutter (13279): Dialog Dissmiss from callback

希望这会有所帮助。

,

我正在尝试使用 Awesome Dialogue,然后使用属性“useRootNavigator”并将其设置为 true。

AwesomeDialog(
useRootNavigator: true,context: context,headerAnimationLoop: false,title: 'Go',desc: 'Continue Adding ',btnOkOnPress: () {
Navigator.push(
context,MaterialPageRoute(builder: (context) => Page2()));
},btnOkIcon: Icons.receipt,onDissmissCallback: () {
debugPrint('Dialog Dissmiss from callback');
},btnOkText: "Add More members",btnCancelOnPress: () {
Navigator.push(
context,new MaterialPageRoute(builder: (context) => Home()));
},btnCancelIcon: Icons.home,btnCancelText: "Go to Home Page")
..show();

推荐阅读
  • 使用 Azure Service Principal 和 Microsoft Graph API 获取 AAD 用户列表
    本文介绍了一段通用代码示例,该代码不仅能够操作 Azure Active Directory (AAD),还可以通过 Azure Service Principal 的授权访问和管理 Azure 订阅资源。Azure 的架构可以分为两个层级:AAD 和 Subscription。 ... [详细]
  • 本文详细介绍了如何使用 Yii2 的 GridView 组件在列表页面实现数据的直接编辑功能。通过具体的代码示例和步骤,帮助开发者快速掌握这一实用技巧。 ... [详细]
  • Explore a common issue encountered when implementing an OAuth 1.0a API, specifically the inability to encode null objects and how to resolve it. ... [详细]
  • 本文深入探讨了HTTP请求和响应对象的使用,详细介绍了如何通过响应对象向客户端发送数据、处理中文乱码问题以及常见的HTTP状态码。此外,还涵盖了文件下载、请求重定向、请求转发等高级功能。 ... [详细]
  • 本文详细探讨了HTML表单中GET和POST请求的区别,包括它们的工作原理、数据传输方式、安全性及适用场景。同时,通过实例展示了如何在Servlet中处理这两种请求。 ... [详细]
  • 探讨了如何解决Ajax请求响应时间过长的问题。本文分析了一个从服务器获取少量数据的Ajax请求,尽管服务器已经对JSON响应进行了缓存,但实际响应时间仍然不稳定。 ... [详细]
  • 解决FCKeditor应用主题后上传问题及优化配置
    本文介绍了在Freetextbox收费后选择FCKeditor作为替代方案时遇到的上传问题及其解决方案。通过调整配置文件和调试工具,最终解决了上传失败的问题,并对相关配置进行了优化。 ... [详细]
  • 本文详细探讨了在微服务架构中,使用Feign进行远程调用时出现的请求头丢失问题,并提供了具体的解决方案。重点讨论了单线程和异步调用两种场景下的处理方法。 ... [详细]
  • 本文将详细介绍NSRunLoop的工作原理,包括其基本概念、消息类型(事件源)、运行模式、生命周期管理以及嵌套运行等关键知识点,帮助开发者更好地理解和应用这一重要技术。 ... [详细]
  • 本文探讨了在支付项目开发中使用SS5 Socket Server实现内部网络访问外部网络的技术方案。详细介绍了SS5的安装、配置及性能测试过程,旨在为面临相同需求的技术人员提供参考。 ... [详细]
  • 请看|差别_Android 6.0 运行时权限处理解析
    请看|差别_Android 6.0 运行时权限处理解析 ... [详细]
  • Working with Errors in Go 1.13
    作者|陌无崖 ... [详细]
  • 利用HTML5 Canvas高效构建电信网络拓扑图
    电信网络拓扑图在实际应用中具有很高的实用价值。本文介绍了一个基于HTML5 Canvas的电信网络拓扑图项目,不仅实现了基本的图形展示功能,还加入了自动布局和属性栏功能,使项目更加完善。此Demo经过细微调整即可直接应用于实际项目中。 ... [详细]
  • 学习目的:1.了解android线程的使用2.了解主线程与子线程区别3.解析异步处理机制主线程与子线程:所谓主线程,在Windows窗体应用程序中一般指UI线程,这个是程序启动的时 ... [详细]
  • 本文探讨了在不使用服务器控件的情况下,如何通过多种方法获取并修改页面中的HTML元素值。除了常见的AJAX方式,还介绍了其他可行的技术方案。 ... [详细]
author-avatar
HoerenRegen
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有