随笔-57  评论-117  文章-1  trackbacks-0

对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: { 
            paddingTop: '15px', 
            paddingBottom: '12px', 
            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;
}
 
.btn {
    border: 1px solid #ccc;
    /*background-color: #ccc;*/
    border-radius: 5px;
    min-width: 25%;
    width: auto;
    font-size: 12px;
}
 
.ok-btn {
    /*background-color: #ccc;*/
}
 
.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" />
    <link rel="stylesheet" href="blockUI/block.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>

image

作者:hoojo
出处:
blog:http://blog.csdn.net/IBM_hoojo
         http://hoojo.cnblogs.com
本文版权归作者和博客园共有,欢迎转载,但未经作者同意必须保留此段声明,且在文章页面明显位置给出原文连接,否则保留追究法律责任的权利。


版权所有,转载请注明出处 本文出自:
分享道版权所有,欢迎转载,转载请注明出处,谢谢
posted on 2012-01-09 14:19 hoojo 阅读(3274) 评论(3)  编辑  收藏 所属分类: Ajax【富客户端技术】HTML/CSSjQuery

评论:
# re: jquery blockUI 扩展插件 Dialog 2012-01-09 17:30 | 阳葵
给个小建议:
对于参数的传递,建议不要使用固定的位置,比如你的方法当中约定了第几个参数是什么内容,第几个参数是什么内容。我觉得这种方式不灵活,而且增加学习成本。

建议使用:json对象。这样就不受参数的位置限制了。直接要调用方传入:$.alert({
message:"",onOk:function(){}
})  回复  更多评论
  
# re: jquery blockUI 扩展插件 Dialog 2012-01-10 09:14 | hoojo
@阳葵
可以这样传递  回复  更多评论
  
# re: jquery blockUI 扩展插件 Dialog 2012-01-11 09:10 | tb
好久没有用jquery了   回复  更多评论
  

只有注册用户登录后才能发表评论。


网站导航: