热门标签 | 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();

推荐阅读
  • 本文介绍了南邮ctf-web的writeup,包括签到题和md5 collision。在CTF比赛和渗透测试中,可以通过查看源代码、代码注释、页面隐藏元素、超链接和HTTP响应头部来寻找flag或提示信息。利用PHP弱类型,可以发现md5('QNKCDZO')='0e830400451993494058024219903391'和md5('240610708')='0e462097431906509019562988736854'。 ... [详细]
  • 图像因存在错误而无法显示 ... [详细]
  • Android实战——jsoup实现网络爬虫,糗事百科项目的起步
    本文介绍了Android实战中使用jsoup实现网络爬虫的方法,以糗事百科项目为例。对于初学者来说,数据源的缺乏是做项目的最大烦恼之一。本文讲述了如何使用网络爬虫获取数据,并以糗事百科作为练手项目。同时,提到了使用jsoup需要结合前端基础知识,以及如果学过JS的话可以更轻松地使用该框架。 ... [详细]
  • XML介绍与使用的概述及标签规则
    本文介绍了XML的基本概念和用途,包括XML的可扩展性和标签的自定义特性。同时还详细解释了XML标签的规则,包括标签的尖括号和合法标识符的组成,标签必须成对出现的原则以及特殊标签的使用方法。通过本文的阅读,读者可以对XML的基本知识有一个全面的了解。 ... [详细]
  • Iamtryingtomakeaclassthatwillreadatextfileofnamesintoanarray,thenreturnthatarra ... [详细]
  • 本文介绍了Web学习历程记录中关于Tomcat的基本概念和配置。首先解释了Web静态Web资源和动态Web资源的概念,以及C/S架构和B/S架构的区别。然后介绍了常见的Web服务器,包括Weblogic、WebSphere和Tomcat。接着详细讲解了Tomcat的虚拟主机、web应用和虚拟路径映射的概念和配置过程。最后简要介绍了http协议的作用。本文内容详实,适合初学者了解Tomcat的基础知识。 ... [详细]
  • 本文介绍了如何使用JSONObiect和Gson相关方法实现json数据与kotlin对象的相互转换。首先解释了JSON的概念和数据格式,然后详细介绍了相关API,包括JSONObject和Gson的使用方法。接着讲解了如何将json格式的字符串转换为kotlin对象或List,以及如何将kotlin对象转换为json字符串。最后提到了使用Map封装json对象的特殊情况。文章还对JSON和XML进行了比较,指出了JSON的优势和缺点。 ... [详细]
  • 本文介绍了一个React Native新手在尝试将数据发布到服务器时遇到的问题,以及他的React Native代码和服务器端代码。他使用fetch方法将数据发送到服务器,但无法在服务器端读取/获取发布的数据。 ... [详细]
  • 使用nodejs爬取b站番剧数据,计算最佳追番推荐
    本文介绍了如何使用nodejs爬取b站番剧数据,并通过计算得出最佳追番推荐。通过调用相关接口获取番剧数据和评分数据,以及使用相应的算法进行计算。该方法可以帮助用户找到适合自己的番剧进行观看。 ... [详细]
  • android listview OnItemClickListener失效原因
    最近在做listview时发现OnItemClickListener失效的问题,经过查找发现是因为button的原因。不仅listitem中存在button会影响OnItemClickListener事件的失效,还会导致单击后listview每个item的背景改变,使得item中的所有有关焦点的事件都失效。本文给出了一个范例来说明这种情况,并提供了解决方法。 ... [详细]
  • 本文介绍了Redis的基础数据结构string的应用场景,并以面试的形式进行问答讲解,帮助读者更好地理解和应用Redis。同时,描述了一位面试者的心理状态和面试官的行为。 ... [详细]
  • 阿,里,云,物,联网,net,core,客户端,czgl,aliiotclient, ... [详细]
  • Voicewo在线语音识别转换jQuery插件的特点和示例
    本文介绍了一款名为Voicewo的在线语音识别转换jQuery插件,该插件具有快速、架构、风格、扩展和兼容等特点,适合在互联网应用中使用。同时还提供了一个快速示例供开发人员参考。 ... [详细]
  • 本文介绍了在MFC下利用C++和MFC的特性动态创建窗口的方法,包括继承现有的MFC类并加以改造、插入工具栏和状态栏对象的声明等。同时还提到了窗口销毁的处理方法。本文详细介绍了实现方法并给出了相关注意事项。 ... [详细]
  • 本文介绍了如何使用jQuery和AJAX来实现动态更新两个div的方法。通过调用PHP文件并返回JSON字符串,可以将不同的文本分别插入到两个div中,从而实现页面的动态更新。 ... [详细]
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社区 版权所有