网页开发中,弹窗还是很有必要的。本人比较喜欢jquery ui的dialog。

但是jquery dialog中也有一些略显不方便的,如:没有z-index的参数设置,脚部的按钮样式没办法自定义……

我自己简单地写了个使用jquery dialog封装函数,有兴趣的朋友看看。

JavaScript(看起来有点多,但放到vs里,ctrl+m+o,还是比较清楚明了的):

$.ivanjs = $.ivanjs || {};
$.ivanjs.com = $.ivanjs.com || {}; $.ivanjs.com = {
//other function //弹窗
showWin: function (content, options) {
var contentDiv = content;
//检查传递过来的参数类型是否为Jquery对象
if (!(content instanceof $)) {
//如果是字符串,则构造一个Jquery对象
if (typeof (content) == "string") {
contentDiv = $("<div>" + content + "</div>");
} else {
alert("弹窗内容参数无效,必须为jquery元素对象或者字符串");
return null;
}
} //默认设置
var _options = {
autoOpen: true,
modal: true,
zIndex: null,
full: false,//是否全屏
destroyEnable: true,
afterOpen: function () {
//打开之后的回调
}
}; //避免为空对象
options = options || {};
//把按钮对象转换为jquery ui能识别的格式参数
var customBtns = options.buttons || [];
options.buttons = {};
for (var i = 0; i < customBtns.length; i++) {
var btnObj = customBtns[i];
options.buttons[btnObj.text] = btnObj.handler || function () {};
} //调用者的设置优先
_options = $.extend({}, _options, options); //关闭后的回调
var closeCallback = _options.close;
var isCodeElement = $("body").find(contentDiv).length == 0;
_options.close = function () {
if (closeCallback) {
closeCallback();
}
//如果是用代码构造的jquery元素,则销毁。避免下次构造时页面中反复存在
if (_options.autoOpen && _options.destroyEnable && isCodeElement) {
setTimeout(function () {
contentDiv.remove();
}, 250);
}
}; //初始化之后立即打开的
if (_options.autoOpen && !contentDiv.length) {
alert("弹窗内容要显示的jquery元素不存在,selector:" + contentDiv.selector);
return null;
} var dialogObj = contentDiv.dialog(_options); updateDialogStyle(); if (_options.autoOpen && _options.afterOpen) {
_options.afterOpen();
} //如果是初始化之后,再手动打开的,则添加一个打开的“开关”,供外部使用
dialogObj.open = function () {
if (!dialogObj.length) {
alert("弹窗内容要显示的jquery元素不存在,selector:" + dialogObj.selector);
} dialogObj.dialog("open"); updateDialogStyle(); if (_options.afterOpen) {
_options.afterOpen();
}
}; return dialogObj; //应用自定义的样式,更新弹窗样式
function updateDialogStyle() {
var uiDialog = contentDiv.parent(".ui-dialog"); //z-index
if (_options.zIndex) {
uiDialog.css({ "z-index": _options.zIndex });
} //按钮样式
if (customBtns.length) {
for (var j = 0; j < customBtns.length; j++) {
var cbtn = customBtns[j];
var btnArr = uiDialog.find("button:contains('" + cbtn.text + "')");
var btn = btnArr;
if (btnArr.length > 1) {
for (var k = 0; k < btnArr.length; k++) {
btn = $(btnArr[k]);
var res = $(btn.children()).filter(function (index) {
return $(this).text() == cbtn.text;
});
if (res.length>0) {
break;
}
}
} //覆盖全部class样式
if (cbtn.className) {
btn.attr("class", cbtn.className);
}
//增加
if (cbtn.addClass) {
btn.addClass(cbtn.addClass);
}
//移除
if (cbtn.removeClass) {
btn.removeClass(cbtn.removeClass);
}
//内嵌样式
if (cbtn.style) {
for (var styleName in cbtn.style) {
btn.css(styleName, cbtn.style[styleName]);
}
}
//图标
if (cbtn.icon) {
btn.prepend($("<span>" + cbtn.icon + "</span>"));
}
//ko绑定
if (cbtn["data-bind"]) {
btn.attr("data-bind", cbtn["data-bind"]);
} }
//只需更新一次,然后重置按钮参数变量,避免打开之后反复更新按钮样式
customBtns = [];
} //宽和高
if (_options.full) {
setFullScreen(); $(window).resize(function () {
setFullScreen();
}).resize(); //全屏样式
function setFullScreen() {
var uiAllWidth = $(window).width() - 20,
uiAllHeight = $(window).height() - 30; uiDialog.css("width", uiAllWidth);
uiDialog.css("height", uiAllHeight);
uiDialog.css("left", "5px");
uiDialog.css("top", "5px"); var uiFooter = uiDialog.find(".ui-dialog-buttonpane"),
uiHeader = uiDialog.find(".ui-dialog-titlebar"),
uiFooterH = uiFooter.height(),
uiHeaderH = uiHeader.height(); console.log("高:全部" + uiAllHeight + ";头" + uiHeaderH + ";脚" + uiFooterH); contentDiv.css("height", uiAllHeight - uiHeaderH - uiFooterH - 50);
}
}
else {
var uiWidth = parseInt(uiDialog.css("width")),
winWidth = $(window).width(); if (winWidth <= uiWidth) {
uiDialog.css("width", winWidth - 10);
} else if (_options.width) {
uiDialog.css("width", _options.width);
}
}
}
}
};

栗子-html:

<!DOCTYPE html>
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8"/>
<title></title> </head>
<body> <div>
<input type="button" id="openFormDialog_body" value="打开子表单" />
</div> <div id="dialogform" title="Create new user">
<input type="text" value=" " />
</div> </body>
</html>

栗子-js:

//测试1:自动弹出
$.ivanjs.com.showWin("yes"); $.ivanjs.com.attachConsole(); //测试2:手动弹窗
var bodyDialog = $.ivanjs.com.showWin($("#dialogform"), {
autoOpen: false,
height: 300,
width: 550,
full: false,
zIndex:999,
modal: true,
buttons: [
{ text: "确认", className: "yourClass", style: { color: "green" },icon:"<fa>123</fa>", "data-bind":"click:myClick", handler: function () { } },
{text:"确认取消"}
],
close: function () { }
});

呃,如果要运行的话,当然要在示例的html里引入示例js……怎么引用JS,这个就不好说了吧……

另外,console.log,ie9及以下的浏览器不支持哦,以上代码里的console.log只是为了方便调试,可以注释掉的。

使用jquery dialog的更多相关文章

  1. jquery dialog open后,服务器端控件失效的快速解决方法

    jquery dialog为我们提供了非常漂亮实用的对话框,比单调的alert.confirm.prompt好用很多. 在使用jquery与.net共同开发时,直接调用jquery dialog的op ...

  2. jQuery Dialog弹出层对话框插件

    Dialog.js的相关注释已经添加,可以按照注释,进行相关样式的修改,适用于自定义的各个系统! dialog.js /** * jQuery的Dialog插件. * * @param object ...

  3. JQuery Dialog 禁用X按钮关闭对话框,-摘自网络

    JQuery Dialog 禁用X按钮关闭对话框,禁用ESC键关闭代码如下:$("#div1").dialog({   closeOnEscape: false,   open: ...

  4. MVC3+EF5.0 code first+Flexigrid+ajax请求+jquery dialog 增删改查

    MVC3+EF5.0 code first+Flexigrid+ajax请求+jquery dialog 增删改查 本文的目的:   1.MVC3项目简单配置EF code first生成并初始化数据 ...

  5. jquery dialog的一些坑

    jquery dialog工具可以方便的生成一个弹出框,但是在一些需要多个弹出框的应用场景上会有一些bug 具体场景: 当使用过一次模态框之后,使用另外的一个模态框时,已经消失不见的模态框会重新出来 ...

  6. jQuery dialog 简介

    dialog是jQuery UI 库的一个UI组件,所以使用dialog时,不仅要引入jQuery.js(因为它只是轻量级的基础框架),还需要引入jQueryUI的js及相关css文件 示例: < ...

  7. jQuery.dialog

    本篇文章主要是对JQUERY中dialog的用法进行了详细的分析介绍,需要的朋友可以过来参考下,希望对大家有所帮助 今天用到了客户端的对话框,把 jQuery UI 中的对话框学习了一下. 准备 jQ ...

  8. JQUERY dialog的用法详细解析

    本篇文章主要是对JQUERY中dialog的用法进行了详细的分析介绍,需要的朋友可以过来参考下,希望对大家有所帮助 今天用到了客户端的对话框,把 jQuery UI 中的对话框学习了一下. 准备 jQ ...

  9. 解决 jquery dialog 弹框destroy销毁方法不能把弹出元素设置成初始状态

    在使用jquery ui中的dialog弹出窗口的时候遇到一个问题,就是页面弹出窗口关闭后希望表单元素能回到初始状态 例如文本框输入内容后关闭dialog后里面的内容清除,使用了destroy方法也不 ...

随机推荐

  1. redux状态管理和react-redux的结合使用

    一:调试 注意:Redux调试工具.谷歌中搜redux同理react 新建store的时候判断window.devToolsExtension使用compose(组合函数)结合thunk插件和wind ...

  2. cas如何去掉HTTPS认证?

    说明:默认情况下HTTP也是可以访问CAS SERVER的,但认证,登陆,退出等操作均没有任何的效果.所以必须作出下面的修改  1.进入WEB-INF\spring-configuration目录 打 ...

  3. UML类图几种关系的总结 【转】

    在UML类图中,常见的有以下几种关系:泛化(Generalization),  实现(Realization),关联(Association),聚合(Aggregation),组合(Compositi ...

  4. vue-resource文档详细解读

    Vue可以构建一个完全不依赖后端服务的应用,同时也可以与服务端进行数据交互来同步界面的动态更新.Vue通过插件的形式实现了基于AJAX,JSPNP等技术的服务端通信. vue-resource是一个通 ...

  5. linux 调度总结(转载)

    调度: 操作系统的调度程序的两项任务: 1: 调度: 实现调度策略,决定就绪的进程.线程竞争cpu的次序的裁决原则.说白了就是进程和线程何时应该放弃cpu和选择那个就绪进程.线程来执行. 2: 分派: ...

  6. POJ 2664 Prerequisites?(简单题)

    [题意简述]:k:已经选择的科目数:m:选择的科目类别:c:能够选择的科目数.r:要求最少选择的科目数量 在输入的k和m以下的一行是选择的科目号. 比如: 3 2 //3是他选择了3科.2表示选择了两 ...

  7. MapReduce报错:Error: java.io.IOException: Initialization of all the collectors failed. Error in last collector was :interface javax.xml.soap.Text

    这个问题折腾了我一天了,最主要的是真的不懂在哪里看log,所以虽然折腾地很没有道理但还是一直在折腾. 这个问题很好解决,在main函数处错误import了 javax.xml.soap.Text,应该 ...

  8. promise对象解决回调地狱

    先放一张图片感受一下回调地狱 看起来是真的很让人头痛的东西 而现在我这里使用promise对象来解决回调地狱 采用链式的 then,可以指定一组按照次序调用的回调函数. 这时,前一个 then 里的一 ...

  9. android 步骤控件的使用

    有的时候我们做Android开发会用到表示步骤的需求.这时候github给我们提供了一个非常好地表示步骤的组件,使用她仅仅须要4步就能够完毕了. 项目地址https://github.com/anto ...

  10. [HTML5] Track First Contentful Paint with PerformanceObserver and Google Analytics

    "If you can't measure it, you can't improve it." The first step when doing performance wor ...