layer插件如何在弹出层中弹出一警告提示并关闭弹出层
来源:互联网 发布:淘宝联盟手机版登录 编辑:程序博客网 时间:2024/05/29 16:27
昨天layer插件弹出层关闭问题弄的我直挠头,短短几行代码,用了我将近2个钟头才解决。我的使用场景是这样。在页面中用layer.open弹出一个层,在层内是微信支付二维码,客户扫码支付。支付成功后关闭此弹出层,并提示项目投递成功,然后再跳转到其他页面。为了监控微信二维码扫码支付是否成功。我利用了每隔三秒,查询下支付订单,查看支付订单的支付状态是否改变。在实际操作中由于使用的是location.href做跳转,然而跳转执行的非常慢,要10几秒才能成功,这不能忍。只能退而求其次,只是提示投递成功,然后关闭弹出层。由于关闭弹出层,及弹出警告提示的相关代码是在弹出层所在页面执行。实际代码在执行过程当中遇到了各种问题。
$(function () { setInterval(GetDeliverProjectPayStatusSuccess, 3000); }); function GetDeliverProjectPayStatusSuccess() { $.post("/ajax/GetDeliverProjectPayStatus.ashx", { OrderNo:"<%=Request.QueryString["OrderNo"] %>" }, function (data) { console.info(data); if (data == 1) { parent.layer.closeAll(); layer.alert("项目投递成功"); } }); }
首先尝试的代码如上。先关闭弹出层,然后提示项目投递成功。这尝试的结果是,弹出层被关闭了。却没有任何提示。为什么这样执行,分析的结果是关闭弹出层,意味着弹出页面被关闭。弹出页面被关闭了。在弹出页面存在的layer.alert代码也就无从执行。然后这两行代码调换位置。可仍然是弹出层被关闭了。却没有提示。这个分析的原因是就像javascript中的alert与location.href一样。如果先alert然后在location.href,也不会执行alert,或者说其实有执行,但是由于系统执行的非常快,还没等你看到alert信息,浏览器已经跳转了。这里也是,还没等你看到项目投递成功的信息,弹出层已经关闭了。
又尝试了带回调函数的layer.alert,等客户点击layer.alert的确定按钮后再执行parent.layer.closeAll() 来关闭弹出层。然而残酷的现实是,由于这个是每隔三秒执行一次post请求,结果就是如果你点击关闭按钮过慢,它会每隔3秒弹出项目投递成功的提示。这怎么能用。难道你要求客户必须快速反应,点击关闭按钮?经过不断尝试,最终还是找到了一个方法解决了这个问题。能够很好解决此问题的代码如下:
$(function () { setInterval(GetDeliverProjectPayStatusSuccess, 3000); }); function GetDeliverProjectPayStatusSuccess() { $.post("/ajax/GetDeliverProjectPayStatus.ashx", { OrderNo:"<%=Request.QueryString["OrderNo"] %>" }, function (data) { console.info(data); if (data == 1) { parent.layer.alert("项目投递成功"); var index = parent.layer.getFrameIndex(window.name); //先得到当前iframe层的索引 parent.layer.close(index); //再执行关闭 } }); }
阅读全文
0 0
- layer插件如何在弹出层中弹出一警告提示并关闭弹出层
- 弹出层插件layer
- Layer弹出层插件
- layer弹出的iframe层在执行完毕后关闭当前弹出层
- layer弹出层全屏及关闭
- 一个弹出层的效果插件 layer
- jQuery插件之layer弹出层
- layer弹出层
- 页面弹出层 layer
- layer弹出层用法
- layer 弹出iframe层
- layer 弹出层
- 弹出层 layer !!!
- 弹出层 layer !!!常用
- Layer弹出层
- jQuery layer弹出层
- layer弹出层详解
- layer弹出层
- [Android]笔记13:改变分割条、基于数据的ListView
- android好用的资源
- Android+FFmpeg+OpenSL ES音频解码播放
- 关于程序猿的经典段子:杀一个程序员不需用枪,改三次需求即可
- 1262: 判断奇偶性
- layer插件如何在弹出层中弹出一警告提示并关闭弹出层
- Linux环境变量设置
- 【ImageView】图片自适应及android:scaleType属性
- 判断网络状态 0-无网络 1- wifi 2-流量
- 底部导航BottomNavigationView+ViewPager 底部图标不放大解决办法
- android 格式化代码
- Halcon11算子学习1 Chapter1-5
- Android实现音频条形图效果
- python and 和 or 语法规则