基于bootstrap模态框的二次封装
一、参数设置
$.beamDialog(options);
var defaults = {
title:'标题',
content:'内容',
showCloseButton:true,
//显示关闭按钮
otherButtons:[],
//其他按钮文本,样式默认,["确定","取消"]
otherButtonStyles:[],
//其他按钮的样式,['btn-primary','btn-primary'],bootstrap按钮样式
bsModalOption:{},
//默认的bootstrap模态对话框参数
dialogShow:function(){},
//对话框即将显示事件
dialogShown:function(){},
//对话框已经显示事件
dialogHide:function(){},
//对话框即将关闭
dialogHidden:function(){},
//对话框已经关闭事件
clickButton:function(sender,modal,index){}
}
二、完整例子代码
$.beamDialog({
title:'系统提示',
content:'确认删除本条记录?',
showCloseButton:true,
otherButtons:["确定","取消"],
otherButtonStyles:['btn-primary','btn-primary'],
bsModalOption:{keyboard: true},
dialogShow:function(){
alert('即将显示对话框');
},
dialogShown:function(){
alert('显示对话框');
},
dialogHide:function(){
alert('即将关闭对话框');
},
dialogHidden:function(){
alert('关闭对话框');
},
clickButton:function(sender,modal,index){
alert('选中第'+index+'个按钮:'+sender.html());
$(this).closeDialog(modal);
}
});
三、简单调用代码例子
obj.event function(){
$.beamDialog({
title:'系统提示',
content:'确认删除本条记录?'
});
}
封装代码:
(function($) {
$.fn.beamDialog = function(options) {
var defaults = {
title: '标题',
content: '<p>内容</p>',
showCloseButton: true,
otherButtons: [],
otherButtonStyles: [],
bootstrapModalOption: {},
dialogShow: function() {},
dialogShown: function() {},
dialogHide: function() {},
dialogHidden: function() {},
clickButton: function(sender, modal, index) {}
};
options = $.extend(defaults, options);
var modalID = ''; //生成一个唯一的ID
function random(a, b) {
return Math.random() > 0.5 ? -1 : 1;
} function getModalID() {
return "beamDialog-" + ['1', '2', '3', '4', '5', '6', '7', '8', '9', '0', 'Q', 'q', 'W', 'w', 'E', 'e', 'R', 'r', 'T', 't', 'Y', 'y', 'U', 'u', 'I', 'i', 'O', 'o', 'P', 'p', 'A', 'a', 'S', 's', 'D', 'd', 'F', 'f', 'G', 'g', 'H', 'h', 'J', 'j', 'K', 'k', 'L', 'l', 'Z', 'z', 'X', 'x', 'C', 'c', 'V', 'v', 'B', 'b', 'N', 'n', 'M', 'm'].sort(random).join('').substring(5, 20);
} $.fn.extend({
closeDialog: function(modal) {
var modalObj = modal;
modalObj.modal('hide');
}
}); return this.each(function() {
var obj = $(this);
modalID = getModalID();
var tmpHtml = '<div class="modal fade" id="{ID}" role="dialog" aria-hidden="true"><div class="modal-dialog"><div class="modal-content"><div class="modal-header"><button type="button" class="close" data-dismiss="modal"><span aria-hidden="true">×</span></button><h6 class="modal-title">{title}</h6></div><div class="modal-body">{body}</div><div class="modal-footer">{button}</div></div></div></div>';
var buttonHtml = '<button class="btn" data-dismiss="modal" aria-hidden="true">关闭</button>';
if (!options.showCloseButton && options.otherButtons.length > 0) {
buttonHtml = '';
}
//生成按钮
var btnClass = 'cls-' + modalID;
for (var i = 0; i < options.otherButtons.length; i++) {
buttonHtml += '<button buttonIndex="' + i + '" class="' + btnClass + ' btn ' + options.otherButtonStyles[i] + '">' + options.otherButtons[i] + '</button>';
}
//替换模板标记
tmpHtml = tmpHtml.replace(/{ID}/g, modalID).replace(/{title}/g, options.title).replace(/{body}/g, options.content).replace(/{button}/g, buttonHtml);
obj.append(tmpHtml); var modalObj = $('#' + modalID);
//绑定按钮事件,不包括关闭按钮
$('.' + btnClass).click(function() {
var index = $(this).attr('buttonIndex');
options.clickButton($(this), modalObj, index);
});
//绑定本身的事件
modalObj.on('show.bs.modal', function() {
options.dialogShow();
});
modalObj.on('shown.bs.modal', function() {
options.dialogShown();
});
modalObj.on('hide.bs.modal', function() {
options.dialogHide();
});
modalObj.on('hidden.bs.modal', function() {
options.dialogHidden();
modalObj.remove();
});
modalObj.modal(options.bootstrapModalOption);
}); }; $.extend({
beamDialog: function(options) {
$("body").beamDialog(options);
}
}); })(jQuery);
基于bootstrap模态框的二次封装的更多相关文章
- 基于bootstrap模态框的alert弹窗
完成的效果如下: html代码: <!-- 弹出框 --> <div class="modal fade" id="alert_like" t ...
- 基于bootstrap模态框的日期选择器
近来由于工作需求,以bootstrap模态框+DIV+CSS+JS做了一个适用于移动端的日期选择器,能够满足多样的需求,目前处于第一个版本,后续可能会继续更新.废话不多说,直接进入制作过程. 首先,需 ...
- 基于bootstrap table配置的二次封装
准备 jQuery js css 引用完毕 开始 如果对bootstrap table 的方法与事件不熟悉: Bootstrap table方法,Bootstrap table事件 <table ...
- 基于bootstrap模态框、fakeLoader实现全局遮罩层
一.fakeLoader.js介绍 fakeLoader.js 是轻量级的 jQuery 插件,帮助你创建动态的全屏加载掩饰微调效果,模拟页面预加载的效果. 插件下载地址:https://github ...
- 第二百四十三节,Bootstrap模态框插件
Bootstrap模态框插件 学习要点: 1.基本使用 2.用法说明 本节课我们主要学习一下 Bootstrap 中的模态框插件,这是一款交互式网站非常常见的 弹窗功能插件. 一.基本使用 使用模态框 ...
- bootstrap模态框modal使用remote第二次加载显示相同内容解决办法
bootstrap模态框modal使用remote动态加载内容,第二次加载显示相同内容解决办法 bootstrap的modal中,使用remote可以动态加载页面到modal-body中,并弹窗显示 ...
- JavaScript:bootstrap 模态框的简单应用
最近用上了bootstrap这个强大的前端框架,有空来总结一下.这里记录下模态框的简单应用. 首先,要在页面中引入相应的js.css文件 <link href="css/bootstr ...
- js控制Bootstrap 模态框(Modal)插件
js控制Bootstrap 模态框(Modal)插件 http://www.cnblogs.com/zzjeny/p/5564400.html
- Bootstrap模态框按钮
1.触发模态框弹窗的代码 这里复制了一段Bootstrap模态框的代码 <h2>创建模态框(Modal)</h2> <!-- 按钮触发模态框 --> <but ...
随机推荐
- java中构造函数的特点
构造函数的名字必须和类名完全相同,构造函数不能有 返回值,就是void 也不要写,构造函数不可以被子类继承 构造函数可以重载但是不可以被子类覆盖. 简单的例子 class A{ A(){ } A(in ...
- TOJ 4523 Transportation
Description Given N stations, you want to carry goods from station 1 to station N. Among these stati ...
- innosetup的静默安装与卸载
静默安装,就是减少程序与用户的交互,一站式的安装过程(一气呵成) 1. 静默安装参数 innosetup的静默安装是通过参数来控制的 1.1. /silent ...
- Java入门系列-11-类和对象
这篇文章为你搞懂类和对象的使用 对象:用来描述客观事物的实体,由一组属性和方法组成,万物皆对象. 属性:就是对象的特征,像身高.体重.颜色 方法:对象的行为,如跑.跳 类:类是模子,定义对象将会拥有的 ...
- HDU 5318——The Goddess Of The Moon——————【矩阵快速幂】
The Goddess Of The Moon Time Limit: 6000/3000 MS (Java/Others) Memory Limit: 65536/65536 K (Java/ ...
- (二) 修改IDEA自带的 maven 仓库
详细可见教程 :https://www.yiibai.com/testng/ 1.新建一个maven项目 Maven简介: Maven是一个项目管理和综合工具.Maven提供了开发人员构建一个完整的生 ...
- 【Linux】time+dd测试硬盘读写速度
dd 是 Linux/UNIX 下的一个非常有用的命令,作用是用指定大小的块拷贝一个文件,并在拷贝的同时进行指定的转换. dd 命令通用语法格式如下: dd if=path/to/input_file ...
- Javaweb的get请求乱码解决
get方式请求:即将参数放在URL中,因此这就涉及到URL的编码了 方式一:[推荐] 方式二: 前端编码: encodeURI(encodeURI("")) 后端解码: java. ...
- mysql 乱码问题的捣鼓
mysql在ubuntu的终端下出现中文乱码的问题: 先学着在不改数据库的情况下对my.cnf配置文件进行修改, 主要的是设置 default-character-set=utf8 但是设置完后数据库 ...
- kafka基本机制
Kafka目前主要作为一个分布式的发布订阅式的消息系统使用,下面简单介绍一下kafka的基本机制 1.3.1 消息传输流程 Producer即生产者,向Kafka集群发送消息,在发送消息之前,会对消息 ...