jquery blockUI 扩展插件 Dialog

简介:

对jQuery blockUI插件进行了小的封装扩展,支持confirm、alert、dialog弹出窗口提示信息,支持按钮回调事件。可以自定义css样式、覆盖blockUI的样式等

首先要到jquery blockUI 官方网址:http://malsup.com/jquery/block/

下载jquery.blockUI JS lib:http://malsup.com/jquery/block/jquery.blockUI.js?v2.38

而且还需要jquery lib:http://ajax.googleapis.com/ajax/libs/jquery/1.4.2/jquery.min.js

 

jquery.blockUI.dialog.js

/***
 * jquery blockUI Dialog plugin 
 * v1.1 
 * @createDate -- 2012-1-4
 * @author hoojo
 * @email hoojo_@126.com
 * @requires jQuery v1.2.3 or later, jquery.blockUI-2.3.8
 * Copyright (c) 2012 M. hoo
 * Dual licensed under the MIT and GPL licenses:
 * http://hoojo.cnblogs.com
 * http://blog.csdn.net/IBM_hoojo
 **/
 
;(function ($) {
    
    var _dialog = $.blockUI.dialog = {};
    
    // dialog 默认配置
    var defaultOptions = {
        css: { 
            padding: '8px', 
            opacity: .7, 
            color: '#ffffff', 
            border: 'none', 
            'border-radius': '10px', 
            backgroundColor: '#000000' 
        },
        
        // 默认回调函数 取消或隐藏 dialog
        emptyHandler: function () {
            $.unblockUI();
        },
        
        // 用户回调函数
        callbackHandler: function (fn) {
            return function () {
                fn();
                defaultOptions.emptyHandler();
            };
        },
        
        // confirm 提示 html元素
        confirmElement: function (settings) {
            settings = settings || {};
            var message = settings.message || "default confirm message!";
            var okText = settings.okText || "ok";
            var cancelText = settings.cancelText || "cancel";
            
            if (typeof settings.onOk !== "function") {
                settings.onOk = this.emptyHandler;
            }
            if (typeof settings.onCancel !== "function") {
                settings.onCancel = this.emptyHandler;
            }
            var okCallback = this.callbackHandler(settings.onOk) || this.emptyHandler;
            var cancelCallback = this.callbackHandler(settings.onCancel) || this.emptyHandler;
            
            var html = [
                '<div class="dialog confirm">',
                '<p>',
                message,
                '</p>',
                '<input type="button" value="',
                okText,
                '" class="btn ok-btn"/>',
                '<input type="button" value="',
                cancelText,
                '" class="btn cancel-btn"/>'
            ].join("");
            
            var $el = $(html);
            $el.find(":button").get(0).onclick =  okCallback;
            $el.find(":button:last").get(0).onclick = cancelCallback;
            return $el;
        },
        
        // alert 提示html元素
        alertElement: function (settings) {
            settings = settings || {};
            var message = settings.message || "default alert message!";
            var okText = settings.okText || "ok";
            
            if (typeof settings.onOk !== "function") {
                settings.onOk = this.emptyHandler;
            }
            
            var okCallback = this.callbackHandler(settings.onOk) || this.emptyHandler;
            
            var html = [
                '<div class="dialog alert">',
                '<p>',
                message,
                '</p>',
                '<input type="button" value="',
                okText,
                '" class="btn ok-btn"/>'
            ].join("");
            
            var $el = $(html);
            
            $el.find(":button:first").get(0).onclick =  okCallback;
            return $el;
        }
    };
    
    var _options = defaultOptions;
    
    // 对外公开的dialog提示html元素,提供配置、覆盖
    $.blockUI.dialog.confirmElement = function () {
        return _options.confirmElement(arguments[0]);
    };
    
    $.blockUI.dialog.alertElement = function () {
        return _options.alertElement(arguments[0]);
    };
    
    // 提供jquery 插件方法
    $.extend({
        confirm: function (opts) {
            var i = (typeof opts === "object") ? 1 : 0;
            var defaults = {
                message: arguments[i++] || "default confirm message!",
                onOk: arguments[i++] || _options.emptyHandler(),
                onCancel: arguments[i++] || _options.emptyHandler(),
                okText: arguments[i++] || "ok",
                cancelText: arguments[i] || "cancel"
            };
            opts = opts || {};
            opts.css = $.extend({}, _options.css, opts.css);
            
            // 覆盖默认配置
            var settings = $.extend({}, _options, defaults, opts);
            settings = $.extend(settings, { message: _dialog.confirmElement(settings) });
            settings = $.extend({}, $.blockUI.defaults, settings);
            $.blockUI(settings);
        },
        alert: function (opts) {
            var i = (typeof opts === "object") ? 1 : 0;
            
            var defaults = {
                message: arguments[i++] || "default alert message!",
                onOk: arguments[i++] || _options.emptyHandler(),
                okText: arguments[i] || "ok"
            };
            
            opts = opts || {};
            opts.css = $.extend({}, _options.css, opts.css);
            
            var settings = $.extend({}, _options, defaults, opts);
            settings = $.extend(settings, { message: _dialog.alertElement(settings) });
            settings = $.extend({}, $.blockUI.defaults, settings);
            $.blockUI(settings);
        },
        
        // dialog提示
        dialog: function (opts) {
            var settings = $.extend({}, $.blockUI.defaults, _options, opts || {});
            $.blockUI(settings);
        },
        // 移除dialog提示框
        removeDialog: function () {
            _options.emptyHandler();
        }
    });
})(jQuery);

 

应用样式文件block.dialog.css

dialog是全局样式,btn是所有按钮的样式、ok-btn是ok按钮样式、cancel-btn是取消按钮样式

.dialog {
    font-size: 12px;
}
 
.dialog .btn {
    border: 1px solid white;
    border-radius: 5px;
    min-width: 25%;
    width: auto;
}
 
.dialog .ok-btn {
    background-color: #ccc;
}
 
.dialog .cancel-btn { 
    /*background-color: #aeface;*/
    margin-left: 10%;
}

 

examples.html

<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">
<html>
  <head>
    <title>blockUI Dialog Examples</title>
    
    <meta http-equiv="author" content="hoojo">
    <meta http-equiv="content-type" content="text/html; charset=UTF-8">
    
    <link rel="stylesheet" href="blockUI/block.dialog.css" />
    <script type="text/javascript" charset="UTF-8" src="mobile/jquery-1.6.4.js"></script>
    <script type="text/javascript" charset="UTF-8" src="blockUI/jquery.blockUI-2.3.8.js"></script>
    <script type="text/javascript" charset="UTF-8" src="blockUI/jquery.blockUI.dialog-1.1.js"></script>
    
    <script type="text/javascript">
        ;(function ($) {
            $(function () {
            
                // dialog 提示框
                $("#dialog").click(function () {
                    //$.dialog();
                    //$.dialog({message: $("#callback")});
                    $.dialog({
                        //theme: true, // 设置主题需要jquery UI http://www.malsup.com/jquery/block/theme.html                
                        title: "dialog",
                        message: $("#callback"),
                        fadeIn: 1000,
                        fadeOut: 1200
                    });
                    setTimeout($.removeDialog, 2000);
                });
                
                // 带确定、取消按钮提示框,支持事件回调,及message等属性配置
                $("#confirm").click(function () {
                    $.confirm({
                        message: "你确定要删除吗?",
                        okText: "确定",
                        cancelText: "取消",
                        onOk: function () {
                            alert("你点击了确定按钮");
                        },
                        onCancel: function () {
                            alert("你点击了取消按钮");
                        }
                    });
                });    
                
                // 警告提示框 对象模式配置css、message、按钮文本提示
                $("#alert").click(function () {
                    $.alert({
                        message: "你确定要删除吗?",
                        okText: "确定",
                        css: {
                            "background-color": "white",
                            "color": "red"
                        },
                        onOk: function () {
                            alert("你点击了确定按钮");
                        }
                    });
                });
                
                // 非对象配置属性,多个参数配置
                /**
                  $.confirm 方法参数config配置介绍:
                  当第一个参数是一个对象:
                  对象中可以出现以下属性配置,并且可以出现$.blockUI的配置
                      {
                        message: arguments[i++] || "default confirm message!",
                        onOk: arguments[i++] || _options.emptyHandler(),
                        onCancel: arguments[i++] || _options.emptyHandler(),
                        okText: arguments[i++] || "ok",
                        cancelText: arguments[i] || "cancel"
                    }
                    message 是提示框的提示信息
                    onOk是确定按钮的click回调函数
                    onCancel 是取消按钮的click事件回调方法
                    okText是ok按钮的文字 默认是ok
                    cancelText是cancel按钮的文本内容
                  
                  如果第一个参数不是一个对象,那么
                      参数1表示 message 及提示文字
                    参数2表示ok按钮的click事件回调函数
                    参数3表示cancel按钮的click事件回调函数
                    参数4表示ok按钮的文本
                    参数5表示cancel按钮的文本内容
                    
                  注意:如果第一参数是一个对象,后面又出现了相应的参数配置;这种情况下对象配置优先于
                  后面的参数配置,而且参数的位置也会改变:
                      参数1是对象配置
                    参数2表示 message 及提示文字
                    参数3表示ok按钮的click事件回调函数
                    参数4表示cancel按钮的click事件回调函数
                    参数5表示ok按钮的文本
                    参数6表示cancel按钮的文本内容
                */
                $("#confirm2").click(function () {
                    $.confirm({ message: "is a message", timeout: 3000 }, "message", function () {
                            alert("success");
                        }, function () {
                            alert("failure");
                        }, "按钮");
                });    
                
                /**
                   第一个参数是对象配置,当对象配置中出现的选项会覆盖后面的参数配置
                   $.alert 方法 config 介绍:
                   当第一个参数 是一个对象:
                     {
                         message: arguments[i++] || "default alert message!",
                         onOk: arguments[i++] || _options.emptyHandler(),
                         okText: arguments[i] || "ok"
                    }
                    message 是提示框的提示信息
                    onOk是确定按钮回调函数
                    okText是ok按钮的文字 默认是ok
                    
                  当第一个参数不是一个对象的情况下,那么
                    参数1表示 message 及提示文字
                    参数2表示ok按钮的click事件
                    参数3表示ok按钮的文本
                    
                    注意:如果第一个参数是一个对象,对象中出现的配置:message、onOk、okText,这些配置将会
                    覆盖后面的配置,也就是说这些配置在第一个参数中出现后,后面的参数就不需要
                 */
                $("#alert2").click(function () {
                    $.alert({
                        css: {
                            "background-color": "red"
                        },
                        timeout: 1200,
                        onOk: function () {
                            alert("确定");
                        }
                    }, 
                    "你有一条消息", 
                    function () {
                        alert("被覆盖");
                    }, "yes?");
                });        
                
                var _confirm = function (msg) {
                    $.confirm({
                        message: msg,
                        onOk: function () {
                            alert("你点击了确定按钮");
                        },
                        onCancel: function () {
                            alert("你点击了取消按钮");
                        }
                    });
                };
                $("#confirm3").click(function () {
                    _confirm("message");
                });        
                
                var _alert = function (msg) {
                    $.alert({
                        message: msg,
                        css: {
                            "background-color": "white",
                            "color": "red"
                        },
                        onOk: function () {
                            alert("你点击了确定按钮");
                        }
                    });
                }
                $("#alert3").click(function () {
                    _alert();
                });    
            });
        })(jQuery);
    </script>
    
  </head>
      
  <body>
      <ul>
          <h2>jQuery blockUI Dialog Demos</h2>
          <li>dialog demo <input type="button" value="dialog" id="dialog"/></li>
          <li>confirm callback demos<input type="button" value="confirm" id="confirm"/></li>
          <li>confirm callback demos 2<input type="button" value="confirm" id="confirm2"/></li>
          <li>confirm callback demos 3<input type="button" value="confirm" id="confirm3"/></li>
          <li>alert callback demos<input type="button" value="alert" id="alert"/></li>
          <li>alert callback demos 2<input type="button" value="alert" id="alert2"/></li>
          <li>alert callback demos 3<input type="button" value="alert" id="alert3"/></li>
      </ul>
      
      <div style="display: none;">
          <div id="callback">
              <p>ok or cancel? asdfaf jQuery blockUI Dialog Demos jQuery blockUI Dialog Demos jQuery blockUI Dialog Demos jQuery blockUI Dialog Demos</p>
              <input type="button" value="OK" class="btn ok-btn"/>
              <input type="button" value="Cancel" class="btn cancel-btn"/>
          </div>
      </div>
  </body>
</html>

截图效果

confirm

image

alert

image






本文转自hoojo博客园博客,原文链接:http://www.cnblogs.com/hoojo/archive/2012/01/05/2313059.html,如需转载请自行联系原作者
目录
相关文章
|
17天前
|
JavaScript 前端开发
jQuery和CSS3滑动展开菜单按钮插件
这是一款jQuery和CSS3滑动展开菜单按钮插件。该滑动展开菜单按钮在用户点击主菜单按钮之后,子菜单以滑动的方式依次展开
56 21
|
13天前
|
JavaScript
jquery文字动画特效插件animatext
jquery文字动画特效插件animatext
39 9
|
16天前
|
移动开发 JavaScript 前端开发
简单易用的jquery响应式轮播图插件ma5slider
ma5slider是一款简单易用的jquery响应式轮播图插件。该轮播图支持鼠标拖拽,可以通过CSS定制外观,支持无限循环模式,内置水平,垂直和淡入淡出三种轮播图过渡动画效果。
|
17天前
|
JavaScript 容器
jQuery文字跑马灯插件Marquee
jQuery.Marquee是一款jQuery文字跑马灯插件。jQuery.Marquee跑马灯插件可以结合使用CSS3动画,制作文字的上下左右移动效果。
|
14天前
|
JavaScript 容器
jquery和CSS3图片排序过滤搜索插件
Filterizr是一款jquery和CSS3图片排序过滤插件。它可以对一组图片进行排序,按条件过滤和按关键字搜索。并在显示结果时使用指定的CSS3动画过渡效果。
24 2
|
14天前
|
JavaScript
jquery和CSS3响应式轮播图插件jcSlider
jcSlider是一款jquery和CSS3响应式轮播图插件。jcSlider使用CSS3过渡动画,它可以和animate.css完美结合,生成60多种轮播图过渡动画效果。
|
16天前
|
JavaScript 容器
jQuery消息通知显示插件
MessageNotifyPlugin是一款简单的jQuery消息通知显示插件。该jQuery消息通知显示插件能够自动生成最新消息和提醒消息两个消息通知按钮。并且可以设置消息的是否已读状态等
21 2
|
18天前
|
JavaScript
jquery图片和pdf文件预览插件
EZView.js是一款jquery图片和pdf文件预览插件。EZView.js可以为图片和pdf格式文件生成在线预览效果。支持的文件格式有pdf、jpg、 png、jpeg、gif。
48 16
|
18天前
|
JavaScript
简洁实用的jQuery进度条插件
这是一款简洁实用的jQuery进度条插件。该插件使用简单,通过在页面中放置指定的HTML代码,即可生成带动画效果的进度条。