下面是写的简单的Jquery弹窗组件 暂不支持animate,只能满足一般的弹窗显示隐藏需求,更多功能后续会完善!网上及jquery组件很多这样的弹窗,但是用别人的感觉心里过不去,所以就随便写写,当做练习下!代码如下:
/**
 * fileoverview WindowAlert
 * @desc jQuery弹窗组件
 * @param {clickElem} 点击元素
 * @param {container} 弹窗窗口最外层容器
 * 默认配置参数如下:{
     eventType: 'click', // 默认为点击
     closed: '.closed', //关闭按钮
     bgColor: '#000',   //默认颜色
     opacity: '0.5',    // 默认透明度
     position: {
        x: 0, //默认情况下居中
        y: 0
     },
     isScroll: true, //默认情况下 窗口随着滚动而滚动
     isResize: true  // 默认情况下 随着窗口缩放而缩放
 }
 * @callback 回调函数  
 */
 
var WindowAlert = (function(){
    function WindowAlert(clickElem,container,config,callback){
        var self = this,
            isIE6 = navigator.userAgent.match(/MSIE 6.0/)!= null;
        self.isIE6 = isIE6;
        if(!(self instanceof WindowAlert)){
            return new WindowAlert(clickElem,container,config,callback);
        }
        
        // 匹配传参数clickElem
        if($.isPlainObject(clickElem)){
            self.clickElem = clickElem;
        }else if(/^\./.test(clickElem)){
            self.clickElem = $(clickElem);
        }else if(/^#/.test(clickElem)){
            self.clickElem = $(clickElem);
        }else if($('.'+clickElem)){
            self.clickElem = $('.'+clickElem);
        }else {
            throw new Error('传递参数不符合!');
        }

// 匹配传参数container
        if($.isPlainObject(container)){
            self.container = container;
        }else if(/^\./.test(container)){
            self.container = $(container);
        }else if(/^#/.test(container)){
            self.container = $(container);
        }else if($('.'+container)){
            self.container = $('.'+container);
        }else {
            throw new Error('传递参数不符合!');
        }
        config = $.extend(WindowAlert.Config,config || {});
        self.config = config || {};
        self._init();

// 显示后 回调
        callback && callback();

// 点击关闭按钮
        $(self.config.closed).bind('click',function(){
            self.hide();
            $('.kissy-mask').hide();

if(true === isIE6) {
                $('body').css({'filter':'','opacity':'','background-color':'',
                            'position':'','top':'','left':'','z-index':''});
            }
            
        });

// 窗口缩放
        $(window).bind('resize',function(){
            t && clearTimeout(t);
            var t = setTimeout(function(){
                if(!$(self.container).hasClass('hidden') && self.config.isResize){
                    self._showDialog(self.container);
                }
            },200);
        });

// 窗口滚动
        $(window).bind('scroll',function(){
            t && clearTimeout(t);
            var t = setTimeout(function(){
                if(!$(self.container).hasClass('hidden') && self.config.isScroll){
                    self._showDialog(self.container);
                }
            },200);
            
        });
    }
    // 默认配置参数
    
    WindowAlert.Config = {
        eventType: 'click', // 默认为点击
        closed: '.closed', //关闭按钮
        bgColor: '#000',   //默认颜色
        opacity: '0.5',    // 默认透明度
        position: {
            x: 0, //默认情况下居中
            y: 0
        },
        isScroll: true, //默认情况下 窗口随着滚动而滚动
        isResize: true  // 默认情况下 随着窗口缩放而缩放
        
    };
    
    WindowAlert.prototype = {
        
        _init: function(){
            var self = this;
            
            $(self.clickElem).each(function(index,item){
                $(item).bind(self.config.eventType,function(){

if(!self.flag){
                        var div = $('<div class="kissy-mask"></div>');
                        $('body').prepend(div);
                        flag = true;
                    }
                    
                    if(false === self.isIE6) {
                        $('.kissy-mask').css({'opacity':self.config.opacity,'background-color':self.config.bgColor,
                            'position':'fixed','top':0,'left':0,'width':'100%','height':'100%','z-index':1});
                    }else {
                        /**$('body').css({'opacity':self.config.opacity,'background-color':self.config.bgColor,
                            'position':'absolute','top':0,'left':0,'z-index':1}); **/

/* IE6不支持fixed 所以对IE6做特殊的处理下 就空白背景*/
                        $('body').css({'position':'absolute','top':0,'left':0,'z-index':1});
                    }

self.show();
                    self._showDialog(self.container);
                });
            })
            
        },

flag: false,

_showDialog: function(container){
            
            var self = this;
            $(container).css({'position':'absolute','z-index':99999});
            var offsetTop = Math.floor(($(window).height() - $(self.container).height())/2) + $(document).scrollTop(),
                offsetLeft = Math.floor(($(window).width() - $(self.container).width())/2) + $(document).scrollLeft();
            
            // 判断x,y位置默认是不是等于0 如是的话 居中 否则 根据传进来的位置重新定位
            if(0 === self.config.position.x && 0 === self.config.position.y){

$(container).offset({'top':offsetTop, 'left':offsetLeft});
            }else{

$(container).offset({'top':self.config.position.y,'left':self.config.position.x});
            }
            
        },
        hide: function(){
            var self = this;
            if(!$(self.container).hasClass('hidden')){
                $(self.container).addClass('hidden');
            }
        },
        show: function(){
            var self = this;
            if($(self.container).hasClass('hidden')){
                $(self.container).removeClass('hidden');
            }
        },
        
        // 销毁
        destory: function(){
            var self = this;
            $(self.clickElem).each(function(index,item){
                $(item).unbind(self.config.eventType);
            });
            self.clickElem = [];
            self.container = [];
        }
    };
    return WindowAlert;
 })();
 
 调用方式如下 :

new WindowAlert(要点击的元素,弹窗的外层容器,{},function(){
            $('.windowAlert').append('<div class="closed">XXX</div>');
        });

Jquery弹窗组件的更多相关文章

  1. 基于JQ的自定义弹窗组件

    <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8&quo ...

  2. Web jquery表格组件 JQGrid 的使用 - 从入门到精通 开篇及索引

    因为内容比较多,所以每篇讲解一些内容,最后会放出全部代码,可以参考.操作中总会遇到各式各样的问题,个人对部分问题的研究在最后一篇 问题研究 里.欢迎大家探讨学习. 代码都经过个人测试,但仍可能有各种未 ...

  3. 扩展 jquery miniui 组件实现自动查询数据

    主题 之前写过一篇文章分享了公司basecode查找数据后台是怎么实现的(http://www.cnblogs.com/abcwt112/p/6085335.html).今天想分享一下公司前台是怎么扩 ...

  4. Web jquery表格组件 JQGrid 的使用 - 11.问题研究

    系列索引 Web jquery表格组件 JQGrid 的使用 - 从入门到精通 开篇及索引 Web jquery表格组件 JQGrid 的使用 - 4.JQGrid参数.ColModel API.事件 ...

  5. Web jquery表格组件 JQGrid 的使用 - 4.JQGrid参数、ColModel API、事件及方法

    系列索引 Web jquery表格组件 JQGrid 的使用 - 从入门到精通 开篇及索引 Web jquery表格组件 JQGrid 的使用 - 4.JQGrid参数.ColModel API.事件 ...

  6. Web jquery表格组件 JQGrid 的使用 - 5.Pager翻页、搜索、格式化、自定义按钮

    系列索引 Web jquery表格组件 JQGrid 的使用 - 从入门到精通 开篇及索引 Web jquery表格组件 JQGrid 的使用 - 4.JQGrid参数.ColModel API.事件 ...

  7. Web jquery表格组件 JQGrid 的使用 - 6.准备工作 & Hello JQGrid

    系列索引 Web jquery表格组件 JQGrid 的使用 - 从入门到精通 开篇及索引 Web jquery表格组件 JQGrid 的使用 - 4.JQGrid参数.ColModel API.事件 ...

  8. Web jquery表格组件 JQGrid 的使用 - 7.查询数据、编辑数据、删除数据

    系列索引 Web jquery表格组件 JQGrid 的使用 - 从入门到精通 开篇及索引 Web jquery表格组件 JQGrid 的使用 - 4.JQGrid参数.ColModel API.事件 ...

  9. Web jquery表格组件 JQGrid 的使用 - 8.Pager、新增数据、查询、刷新、查看数据

    系列索引 Web jquery表格组件 JQGrid 的使用 - 从入门到精通 开篇及索引 Web jquery表格组件 JQGrid 的使用 - 4.JQGrid参数.ColModel API.事件 ...

随机推荐

  1. hive的本地安装部署,元数据存储到mysql中

    要想使用Hive先要有hadoop集群的支持,使用本地把元数据存储在mysql中. mysql要可以远程连接: 可以设置user表,把localhost改为%,所有可连接.记住删除root其他用户,不 ...

  2. 网页三剑客:HTML+CSS+JavaScript 之 HTML的概述

    HTML(超文本标记语言) 什么是HTML? HTML 是用来描述网页的一种语言. HTML 指的是超文本标记语言: HyperText Markup Language HTML 不是一种编程语言,而 ...

  3. vue路由传参的三种基本方式

    现有如下场景,点击父组件的li元素跳转到子组件中,并携带参数,便于子组件获取数据. 父组件中: <li v-for="article in articles" @click= ...

  4. create pdf file using Spire.Pdf or iTextSharp or PdfSharp

    Spire.Pdf: 注:pdf 显示中文一定要设置相应的中文字体,其他外文类似.否则显示为乱码( 如果繁体的服务器上生成的中文内容PDF文档,在简体操作系统保存或并传给简体系统上查看,会存在乱码问题 ...

  5. java程序的加载与执行

    1.编写java源文件   .java 2.生成字节码文件   类名.class 3.JRE,java运行环境,包括JVM(java虚拟机).java基本类库 4.

  6. npm install权限问题,报错:permission denied。

    1.部署gulp项目时,nodeJs和gulp都已经正确安装,在项目内部执行npm install命令时,有些gulp的插件一直下载不成功,报错几种以下错误: “gulp-imagemin: Coul ...

  7. recovery 恢复出厂设置失败Data wipe failed

    最近客户反馈,编译32位的android系统,在recovery中执行恢复出厂设置的时候失败了,失败的打印提升信息如下. Formatting /data... [ 2.191404] E:get_f ...

  8. 逻辑回归&线性回归

    # coding:utf-8 import numpy as np from sklearn import linear_model, datasets import matplotlib.pyplo ...

  9. tkinter中Radiobutton单选框控件(七)

    Radiobutton控件 由于本次内容中好多知识都是之前重复解释过的,本次就不做解释了.不太清楚的内容请参考tkinter1-6节中的内容 import tkinter wuya = tkinter ...

  10. 洗礼灵魂,修炼python(59)--爬虫篇—httplib模块

    httplib 1.简介 同样的,httplib默认存在于python2,python3不存在: httplib是python中http协议的客户端实现,可以用来与 HTTP 服务器进行交互,支持HT ...