zDialog插件网址:http://www.jq22.com/jquery-info2426

再次封装zDialog的代码:

(function ($) {
$.extend({
iDialog: function (param) {
var diag = new Dialog();
if (!param.height && !param.width) {
diag.Width = $(top.window).width();
diag.Height = $(top.window).height();
}
else {
diag.Width = param.width;
diag.Height = param.height;
}
diag.Title = param.title;
diag.Drag = false;
diag.ShowButtonRow = false; //ShowButtonRow:是否不显示按钮栏,值为布尔型(true|false),默认值为false,当定义了OKEvent或调用了addButton时自动设为true。
diag.URL = param.url;
diag.OkEvent = param.OkEvent; //这里是OkEvent而不是OKEvent,是为了隐藏弹出框自带按钮栏
diag.show();
}
});
})(jQuery);

弹出最大化窗口(因插件本身的原因,最大化窗口比实际window大小略小一点):

//弹出最大化窗口
$.iDialog({
title: "修改",
url: "/Auth/UserManage/Edit?id=" + row.Id,
OkEvent: function () {
reloadgrid(); //调用方法刷当前页面,即弹出框的父页面
}
});

弹出一般窗口:

$.iDialog({
title: "添加",
url: "/Auth/UserManage/Add",
width: 500,
height: 300,
OkEvent: function () {
save();
}
});

当窗口中的页面保存成功,需要刷新父窗口,这样调用:

parentDialog.OkEvent();
parentDialog.close();

当窗口中的页面保存成功时,传值给父页面,这样调用:

父页面:

$.iDialog({
title: "添加",
url: "/Auth/UserManage/Add",
width: 500,
height: 300,
OkEvent: function (userName) {
$("#UserName").val(userName)
}
});

子页面:

//保存
function save() {
parentDialog.OkEvent($("#UserName").val());
parentDialog.close();
}

子窗体如何关闭当前窗体,再关闭父窗体,并刷新父窗体的父页面 :

子窗体中数据保存完成后,这样调用:

parentDialog.OkEvent(parentDialog);

子窗体的父窗体中这样调用:

$.iDialog({
title: "添加",
url: "/Auth/UserManage/Add",
width: 800,
height: 400,
OkEvent: function (childDialog) {
parentDialog.OkEvent(); //刷新父窗体的父页面
childDialog.close(); //先关子窗体
parentDialog.close(); //再关父窗体
}
});

封装后,该插件的特点:多层弹出,且弹出到框架的最顶层;使用方便,代码简捷;可以方便地刷新父页面,可以方便地向父页面传值。

示意图:

为什么要封装这个插件?我之前用的插件是lhgDialog,是这样封装的:

/**
* lhgdialog 弹出框封装
* @param 参数
*/
(function ($) {
$.extend({
iDialog: function (param) {
if (typeof (param) == "object") {
var api;
if (frameElement && frameElement.api) {
api = frameElement.api;
$.dialog.setting.zIndex++;
}
else {
$.dialog.setting.zIndex = 1977;
}
var max = false;
if (!param.width && !param.height) {
param.width = $(top.window).width() - 18;
param.height = $(top.window).height() - 45;
param.drag = false;
max = true;
}
var defaultParam = $.extend({
max: false,
min: false,
drag: true,
lock: true,
top: "50%",
width: '800px',
resize: false,
parent: api
}, param);
if (max) {
$.dialog(defaultParam).max();
} else {
$.dialog(defaultParam);
}
} else if (typeof (param) == "string" && param == "close") {
if (frameElement.api.opener.reloadgrid) {
frameElement.api.opener.reloadgrid();
}
else if (frameElement.api.opener.refresh) {
frameElement.api.opener.refresh();
} else {
frameElement.api.opener.location = frameElement.api.opener.location;
}
frameElement.api.close();
}
else {
alert("iDialog参数错误");
}
}
});
})(jQuery);

这样使用:

$.iDialog({
title: '报告流转过程',
height: "500px",
width: "800px",
content: "url:/ViewReport/ViewReport/ReportFlow?ReportCode=" + row.REPORTCODE
});

存在的问题:1、弹出两层窗口,当关闭子窗口时,遮罩层没了,而父窗口还在,这显然是BUG,为什么官网上的Demo是正常的呢?因为它对插件加载有要求,我是在Layout里加载的,所以,所有页面都将这个插件加载一遍,这就是导致BUG的原因。2、如果父页面是Index,弹出Edit窗体,再在Edit窗体里弹出Add窗体,那么在Add窗体里调用方法alert(frameElement.api.opener.location.href);那么提示的url是Index的url而不是Edit的url,这样子窗体能找到父窗体的父页面,而找不到父窗体。

花了一两天时间,终于解决遮罩层问题,代码如下:

/*!
* 框架页面卸载前关闭所有穿越的对话框
* 同时移除拖动层和遮罩层
*/
_top != window && $(window).bind('unload',function()
{
var bl = true; //此处修改
var list = lhgdialog.list;
for( var i in list )
{
if (list[i]) {
//此处修改
if (!lhgdialog.list[i]._lock && !lhgdialog.list[i].parent) {
bl = false;
}
list[i].close();
}
}
_singleton && _singleton.DOM.wrap.remove(); _$doc.unbind('keydown',onKeyDown); if (bl) { //此处修改
$('#ldg_lockmask', _doc)[0] && $('#ldg_lockmask', _doc).remove();
$('#ldg_dragmask', _doc)[0] && $('#ldg_dragmask', _doc).remove();
}
});

父子页面的问题也已解决,代码在上面。

JS弹出框插件zDialog再次封装的更多相关文章

  1. 弹出框插件——dialog

    基于jquery和dot.js弹出框插件,兼容IE6+等其他浏览器. 思想:弹出框元素插入body节点中,并在页面垂直居中显示(fixed定位),触发确定和关闭事件绑定. 注意ie6包含两个问题:一. ...

  2. 弹出框插件layer使用

    layer是一款近年来备受青睐的web弹层组件,她具备全方位的解决方案,致力于服务各水平段的开发人员,您的页面会轻松地拥有丰富友好的操作体验. 插件官方地址:http://layer.layui.co ...

  3. bootstrap中popover.js(弹出框)使用总结+案例

    bootstrap中popover.js(弹出框)使用总结+案例 *转载请注明出处: 作者:willingtolove: http://www.cnblogs.com/willingtolove/p/ ...

  4. 【转】js弹出框、对话框、提示框、弹窗总结

    js弹出框.对话框.提示框.弹窗总结 一.js的三种最常见的对话框 //====================== JS最常用三种弹出对话框 ======================== //弹 ...

  5. js js弹出框、对话框、提示框、弹窗总结

    js弹出框.对话框.提示框.弹窗总结 一.JS的三种最常见的对话框 //====================== JS最常用三种弹出对话框 ======================== //弹 ...

  6. js登录弹出框插件

    第一步:页面引入css:<link rel="stylesheet" type="text/css"" href="common/cs ...

  7. jQuery+css3弹出框插件

    先来看DEMO:https://codepen.io/jonechen/pen/regjGG 插件的开发很简单,运用了CSS3的动画效果,并且弹出框的内容可以自定义.插件的默认配置参数有三个: var ...

  8. 弹出框layer的使用封装

    layer弹出框官方网址:http://layer.layui.com/ layer常用方法的封装:layerTool.jsp layer.config({ extend: 'extend/layer ...

  9. 5月12日上课笔记-js 弹出框、函数、程序调试、基本事件、浏览器对象模型

    一.弹出框 a.提示框 alert(); b.输入框 prompt(); c.确认框 confirm(); var flag= confirm("确认删除吗?"); 二.js程序调 ...

随机推荐

  1. WCF基础教程之异常处理:你的Try..Catch语句真的能捕获到异常吗?

    在上一篇WCF基础教程之开篇:创建.测试和调用WCF博客中,我们简单的介绍了如何创建一个WCF服务并调用这个服务.其实,上一篇博客主要是为了今天这篇博客做铺垫,考虑到网上大多数WCF教程都是从基础讲起 ...

  2. C#Light Unity逻辑热更新解决方案0.20 发布

    之前一直是Beta,这次已经实际运用到项目中间了,去掉beta状态 在项目中使用面对一些新的问题,还有以前没注意的bug. 更新列表 一.增加类中类的支持 二.增加对foreach的支持,同C#语法 ...

  3. [安卓] 14、安卓HTTP——POST和GET用法分析

    内容简介 本文通过建立一个简单的Servlet服务器来分析安卓上用HTTP和服务器通信的细节,旨在演示C/S模式下服务器端和客户端的工作过程. 目录 part.1 用MyEclipse建立一个简单的s ...

  4. WKInterfaceImage 无法更新图片的问题

    最近涉及到AppleWatch的相关项目,但有个奇怪问题无法解决,而且无法理解: 根据不同的用户操作,需要修改播放器的专辑图片. 不知道跟我的项目需求是不是有关系:我需要轮询共享空间,以拿取同步数据, ...

  5. java API:AtomicInteger

    An int value that may be updated atomically. See the java.util.concurrent.atomic package specificati ...

  6. CocoaPods 深入使用

    在 CocoaPods 使用中介绍了基本的使用 写项目的时候想用到 SQLite.swift第三方库,但是问题来了 pod search SQLite.swift  //执行这条语句,搜索不到结果 但 ...

  7. EF架构~通过EF6的DbCommand拦截器来实现数据库读写分离~终结~配置的优化和事务里读写的统一

    回到目录 本讲是通过DbCommand拦截器来实现读写分离的最后一讲,对之前几篇文章做了一个优化,无论是程序可读性还是实用性上都有一个提升,在配置信息这块,去除了字符串方式的拼接,取而代之的是sect ...

  8. Atitit 代理CGLIB 动态代理 AspectJ静态代理区别

    Atitit 代理CGLIB 动态代理 AspectJ静态代理区别 1.1. AOP 代理主要分为静态代理和动态代理两大类,静态代理以 AspectJ 为代表:而动态代理则以 spring AOP 为 ...

  9. fir.im Weekly - 深度揭秘 App 启动全过程

    世纪寒潮席卷全中国,可谓普天之下莫低0℃.无论怎样的严寒都抵挡不了程序员们的创造的激情... 本期的 fir.im Weekly ,最新的 iOS/Android 开发资源,GitHub 源码.前端技 ...

  10. Java——List集合

    package om.hanqi.test; import java.util.ArrayList; import java.util.List; public class Test01 { publ ...