对bootstrap modal的简单扩展封装

参考自:http://www.muzilei.com/archives/677   注:原文不支持bootstrap新版本,并且居中等存在问题

  此段时间一直在学习bootstrap,主要是用于做后台,一直习惯用easyui,ui,jgrid前端框架,以至于并不习惯bootstrap的风格。近来考虑到easyui性能不太好,就用了bootstrap,先说下我所了解的bootstrap. 1.外国的框架用于显示中文看着总是不妥. 2.默认的样式觉得有些松散;比如表格,必须加上table-condensed类才显得紧凑一些。

  进入正题,在使用bootstrap 模态对话框时需要在页面写对话框html,如果一个页面有许多地方需要对话框,那意味着需要写多个,感觉很麻烦,平时不太习惯bootstrap 模态对话框这种方式,所以做了个简单封装及扩展,增加了自定义标题,宽度和高度,并根据宽高居中显示

  调用代码

             <a class="mzDialog" href="#" data-remote="/AccountingPeriod/Init" data-mtitle="哈哈" data-id="m1" data-width="600" data-height="500" data-backdrop=false data-okevent="ok()" data-openevent="open()">弹窗demo</a>

 

        $(".mzDialog").wwDialog();

  目前只支持以data-属性调用,不支持以js方式调用,欢迎大家扩展一下哦

  参数介绍

 id:"modal",//弹窗id
title:"dialog",//弹窗标题
width:"600",//弹窗宽度,暂时不支持%
height:"500",//弹窗高度,不支持%
backdrop:true,//是否显示遮障,和原生bootstrap 模态框一样
keyboard:true,//是否开启esc键退出,和原生bootstrap 模态框一样
remote:"",//加载远程url,和原生bootstrap 模态框一样
openEvent:null,//弹窗打开后回调函数
closeEvent:null,//弹窗关闭后回调函数
okEvent:null//单击确定按钮回调函数

  下面是源代码:

 /*------------------------------------------------------
*封装的dialog插件,基于bootstrap模态窗口的简单扩展
*作者:muzilei
*修改人:lyw 原插件对bootstrap3.3.0不支持
*email:530624206@qq.com
-------------------------------------------------------*/
/*----------------------------------------------------------------------------------------------------
1、bootstrap-wwDialog 插件暂时只有2个按钮,取消和确定,暂不支持自定义按钮,自己可以修改源代码添加此功能。 2、只能使用html data-*方式定义,不支持js初始化时配置参数,自己可以修改源码扩展此功能。 3、宽度和高度建议不要使用百分比 4、注意这里回调函数必需是字符串格式,如okEvent:”ok()” 这里ok函数式自己定义的函数,切记要带();
------------------------------------------------------------------------------------------------------*/
(function ($) {
$.fn.wwDialog = function () {
var defaults = {
id: "modal",//弹窗id
title: "dialog",//弹窗标题
width: "600",//弹窗宽度,暂时不支持%
height: "500",//弹窗高度,不支持%
backdrop: false,//是否显示遮障,和原生bootstrap 模态框一样
keyboard: true,//是否开启esc键退出,和原生bootstrap 模态框一样
remote: "",//加载远程url,和原生bootstrap 模态框一样
openEvent: null,//弹窗打开后回调函数
closeEvent: null,//弹窗关闭后回调函数
okEvent: null//单击确定按钮回调函数
}; //动态创建窗口
var creatDialog = {
init: function (opts) {
var _self = this; //动态插入窗口
var d = _self.dHtml(opts);
$("body").append(d); var modal = $("#" + opts.id); //初始化窗口
//modal.modal(opts);
modal.modal({
backdrop: false,
keyboard: opts.keyboard
});
$(".modal-body").load(opts.remote); //窗口大小位置
var h = modal.height() - modal.find(".modal-header").outerHeight() - modal.find(".modal-footer").outerHeight() - 5;
//modal.css({ 'margin-left': opts.width / 2 * -1, 'margin-top': opts.height / 2 * -1, 'top': '50%' }).find(".modal-body").innerHeight(h);
modal.css({
position: "absolute",
left: ($(window).width() - opts.width) / 2,
top: ($(document).height() - opts.height) / 2
});
$(".modal-body").css({
height: opts.height - 115
});
modal
//显示窗口
.modal('show')
//隐藏窗口后删除窗口html
.on('hidden', function () {
modal.remove();
$(".modal-backdrop").remove();
if (opts.closeEvent) {
eval(opts.closeEvent);
}
})
//窗口显示后
.on('shown', function () { if (opts.openEvent) {
eval(opts.openEvent);
} });
//绑定按钮事件
$(".ok").click(function () {
if (opts.okEvent) {
var ret = eval(opts.okEvent);
if (ret) {
modal.modal('hide');
}
}
});
},
dHtml: function (o) {
return '<div id="' + o.id + '" class="modal fade" role="dialog" tabindex="-1" aria-labelledby="myModalLabel" aria-hidden="true" ><div style=" background-color: #000;bottom: 0;left: 0;position: fixed;right: 0;top: 0;transition: opacity 0.15s linear 0s;opacity: 0.5;"></div><div class="modal-dialog" style="display:table-cell"><div class="modal-content" style="width:' + o.width + 'px;height:' + o.height + 'px;"><div class="modal-header"><button type="button" class="close" data-dismiss="modal" ><span aria-hidden="true">&times;</span><span class="sr-only">Close</span></button><h4 id="myModalLabel" class="modal-title">' + o.title + '</h4></div><div class="modal-body" ><p>正在加载...</p></div><div class="modal-footer"><button class="btn" data-dismiss="modal" aria-hidden="true">取消</button><button class="btn btn-primary ok">确定</button></div></div></div></div>';
}
}; return this.each(function () {
$(this).click(function () {
var opts = $.extend({}, defaults, {
id: $(this).attr("data-id"),
title: $(this).attr("data-mtitle"),
width: $(this).attr("data-width"),
height: $(this).attr("data-height"),
backdrop: $(this).attr("data-backdrop"),
keyboard: $(this).attr("data-keyboard"),
remote: $(this).attr("data-remote"),
openEvent: $(this).attr("data-openEvent"),
closeEvent: $(this).attr("data-closeEvent"),
okEvent: $(this).attr("data-okEvent")
});
$(".modal").remove();
creatDialog.init(opts);
});
}); }; })(jQuery);

对bootstrap modal的简单扩展封装的更多相关文章

  1. bootstrap插件学习-bootstrap.modal.js

    bootstrap插件学习-bootstrap.modal.js 先从bootstrap.modal.js的结构看起. function($){ var Modal = function(){} // ...

  2. 对bootstrap中confirm alert进行封装

    HTML: <!-- system modal start --> <div id="ycf-alert" class="modal"> ...

  3. jeecg扩展封装tag的那些事

    版权声明:本文为楼主原创文章,未经楼主允许不得转载,如要转载请注明来源. 目前公司开发一直使用的是jeecg框架,简单好用,但有时候不如自己写的随心所欲.最近项目遇到一个需求, 想封装配置加解密,本来 ...

  4. Bootstrap Modal 垂直方向加滚动条

    原文链接:http://blog.csdn.net/cyh1111/article/details/52960747 背景 使用Bootstrap Modal实现用户资料修改,由于用户信息过多,默认M ...

  5. [分享] 史上最简单的封装教程,五分钟学会封装系统(以封装Windows 7为例)

    [分享] 史上最简单的封装教程,五分钟学会封装系统(以封装Windows 7为例) 踏雁寻花 发表于 2015-8-23 23:31:28 https://www.itsk.com/thread-35 ...

  6. Bootstrap modal垂直居中

    Bootstrap modal垂直居中   在网上看到有Bootstrap2的Modal dialog垂直居中问题解决方法,这种方法自己试了一下,并不能完全居中,并且窗口的大小不一样的话,每次显示的m ...

  7. Log4net创建日志及简单扩展

    转:http://blog.csdn.net/CHENFEIYANG2009/article/details/5397342 1.概述 log4net是.Net下一个非常优秀的开源日志记录组件.log ...

  8. Bootstrap modal常用参数、方法和事件

    Bootstrap modal(模态窗)常用参数.方法和事件: 参数: 名称 类型 默认值 描述 Backdrop Boolean或字符串“static” True True:有背景,点击modal外 ...

  9. 学习笔记: Expression表达式目录树详解和扩展封装

    1. 表达式链接扩展封装,ORM常用 And  Or /// <summary> /// 表达式访问者 /// </summary> public class Expressi ...

随机推荐

  1. glReadPixels函数

    GPU渲染完数据在显存,回传内存的唯一方式glReadPixels函数... glReadPixels:读取一些像素.当前可以简单理解为“把已经绘制好的像素(它可能已经被保存到显卡的显存中)读取到内存 ...

  2. 单元测试-NUint最基本使用详解

    花了一上午,熟悉了下NUint的使用,网上找了好久,没有很详细的,全是一段文字一写什么都没了 第一步下载:程序安装   :http://launchpad.net/nunitv2/trunk/2.6. ...

  3. 在Egret实现二维码长按识别

      Egret中二维码图片,是在canvas上,无法在微信上长按扫描识别. 由于微信长按识别二维码是截屏扫描原理,所以只要长按当前屏幕任意一张图片,都能够识别当前屏幕上的二维码. 这里把二维码放在ex ...

  4. window删除文件时提示: 源文件名长度大于系统支持的长度

    有时候删除windows中的目录的时候,会出现"源文件名长度大于系统支持的长度", 而导致不能删除, 作为一个程序猿, 怎么可以被这个折服呢, 原理: 利用 Java  递归删除文 ...

  5. UVa 458 - The Decoder

    https://uva.onlinejudge.org/index.php?option=com_onlinejudge&Itemid=8&category=94&page=s ...

  6. Jqurey DOM 操作详解

    一.获取 1.获取内容----.text()  .html()   .value() text() - 设置或返回所选元素的文本内容                         格式:$(选择器) ...

  7. java.io.Serializable 序列化问题

    java.io.Serializable 序列化问题 Person.java package a.b.c; public class Person implements java.io.Seriali ...

  8. C#WebClient常见用法

    System.Net.WebClient.DownloadFile(Uri address, String fileName) namespace:System.Net 参数: address:The ...

  9. texstudio on ubuntu 12.04

    从官网下载针对12.04的版本的texstudio: http://texstudio.sourceforge.net/ 安装deb包:sudo dpkg -i texstudio_xx.deb 运行 ...

  10. Selenium2+python自动化26-js处理内嵌div滚动条

    前言 前面有篇专门用js解决了浏览器滚动条的问题,生活总是多姿多彩,有的滚动条就在页面上,这时候又得仰仗js大哥来解决啦. 一.内嵌滚动条 1.下面这张图就是内嵌div带有滚动条的样子,记住它的长相.