123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231 |
- /*
- *Jquery 简单弹出层插件
- *需要jquery1.3.2或者以上版本支持
- *By 甘强 2011.01
- *1.3版
- * 添加一个延时自动关闭弹出层的功能
- * 添加了弹出层的显示位置的个性选择
- *插件官方地址:http://www.skygq.com/2010/01/05/jquery-simple-popup-overlay-1-3/
- */
- ;(function($){
- //给页面装载CSS样式
- var css = '<style type="text/css">#skygqOverlay{position:fixed;z-index:2000;left:0;top:0;width:100%;height:100%;background:black;}.wrap_out{border:5px solid #000 opacity: 0.2;background:#eee;box-shadow:0 0 6px rgba(0,0,0,.5);-moz-box-shadow:0 0 6px rgba(0,0,0,0.5);-webkit-box-shadow:0 0 6px rgba(0,0,0,.5);position:fixed;z-index:2001;}.wrap_in{background:#fafafa;border:1px solid #ccc;}.wrap_bar{width:100%;background:#f7f7f7;border-top:3px solid #f9f9f9;border-bottom:4px solid #eee;margin-top:2px;}.wrap_title{line-height:5px;background:#f3f3f3;border-top:4px solid #f5f5f5;border-bottom:5px solid #f1f1f1;margin-top:3px;}.wrap_title span{position:relative;margin-left:10px;cursor:text;}.wrap_body{display:inline-block;border-top:1px solid #ddd;background:white;}.wrap_close{margin-top:-18px;color:#34538b;font-weight:bold;margin-right:10px;font-family:Tahoma;text-decoration:none;cursor:pointer;float:right;}.wrap_close:hover{text-decoration:none;color:#f30;}.submit_btn{display:inline-block;padding:3px 12px 1.99px;background:#486aaa;border:1px solid;border-color:#a0b3d6 #34538b #34538b #a0b3d6;color:#f3f3f3;line-height:16px;cursor:pointer;overflow:visible;}.submit_btn:hover{text-decoration:none;color:#ffffff;}.cancel_btn{display:inline-block;padding:3px 12px 1.99px;background:#eee;border:1px solid;border-color:#f0f0f0 #bbb #bbb #f0f0f0;color:#333;line-height:16px;cursor:pointer;overflow:visible;}</style>';
- $("head").append(css);
- var ie6 = ($.browser.msie && $.browser.version < 7);
- var timeout;
- $.fn.skygqbox = function(options){
- if (!this.length) { return this;}
- var s = $.extend({}, $.fn.skygqbox.Default, options || {});
- return this.each(function(){
- $.skygqbox($(this),s)
- });
- };
- $.skygqbox = function(elements,s){
- if ($(elements).length == 0){
- //elements = $("<span></span>").append(elements);
- }
- var s = $.extend({}, $.fn.skygqbox.Default, s || {});
- if ($("#skygqOverlay").length > 0){
- return;
- }
- //弹框的显示初始化
- var WRAP = '<div id="skygqOverlay"></div><div class="wrap_out" id="wrapOut"><div class="wrap_in" id="wrapIn"></div>';
- $("body").append(WRAP);
- if (typeof (timeout) != "undefined"){
- clearTimeout(timeout);
- }
- //一些元素对象
- $.o = {
- s: s,
- ele: elements,
- bg: $("#skygqOverlay"),
- out: $("#wrapOut"),
- bar: $("#wrapBar"),
- clo: $("#wrapClose"),
- bd: $("#wrapBody")
- };
- elements.show();
- $.o.bd.append(elements);
- //尺寸
- $.skygqbox.setSize();
- //定位
- $.skygqbox.setPosition();
- $.o.clo.click(function(){
- $.skygqbox.hide();
- });
- if(s.autoClose > 0){
- timeout = setTimeout($.skygqbox.hide, s.autoClose);
- }
- };
- $.skygqbox.getSize = function(o){
- //获取任意元素的高宽
- var w_h = {};
- $('<div id="wrapClone" style="position:absolute;left:-6000px;"></div>').appendTo("body").append(o.clone());
- w_h.w = $("#wrapClone").width();
- w_h.h = $("#wrapClone").height();
- $("#wrapClone").remove();
- return w_h;
- };
- $.skygqbox.setSize = function(){
- if(!$.o.bd.size() || !$.o.ele.size() || !$.o.bd.size()){
- return;
- }
- //主体内容的尺寸
- var bd_w = parseInt($.o.s.width, 10), bd_h = parseInt($.o.s.height, 10);
- if(!bd_w || bd_w <= 0 ){
- var x_size = $.skygqbox.getSize($.o.ele), w = $(window).width();
- //宽度自动
- bd_w = x_size.w;
- if(bd_w < 50){
- bd_w = 120;
- }else if(bd_w > w){
- bd_w = w - 120;
- }
- }
- $.o.bd.css("width", bd_w);
- $.o.out.css("width", bd_w+2);
- if(bd_h > 0){
- $.o.bd.css("height", bd_h);
- }
- return $.o.bd;
- };
- $.skygqbox.setPosition = function(){
- if(!$.o.bg.size() || !$.o.ele.size() || !$.o.out.size()){
- return;
- }
- var w = $(window).width(),
- h = $(window).height(),
- ph = $("body").height();
- if(ph < h){
- ph = h;
- }
- $.o.bg.css("opacity", $.o.s.opacity);
- if (ie6){
- $.o.bg.css({
- position:"absolute",
- width:w,
- height:ph
- });
- $.o.out.css("position","absolute");
- }
- //主体内容的位置
- //获取当前主体元素的尺寸
- var xh = $.o.out.outerHeight(), xw = $.o.out.outerWidth();
- //弹出层定位:
- switch($.o.s.position){
- case "middle":
- $.o.out.css({
- "top":"50%",
- "left":"50%",
- "marginLeft": '-' + parseInt((xw / 2),10) + 'px',
- "width": xw + 'px',zIndex:$.o.s.index
- });
- if ( !($.browser.msie && $.browser.version < 7)) { // 兼容IE6
- $.o.out.css({marginTop: '-' + parseInt((xh / 2),10) + 'px'});
- }
- break;
- case "left_top":
- $.o.out.css({
- "top":0,
- "left":0,
- "width": xw + 'px',zIndex:$.o.s.index
- });
- break;
- case "left_middle":
- $.o.out.css({
- "top":"50%",
- "left":0,
- "width": xw + 'px',zIndex:$.o.s.index
- });
- if ( !($.browser.msie && $.browser.version < 7)) { // 兼容IE6
- $.o.out.css({marginTop: '-' + parseInt((xh / 2),10) + 'px'});
- }
- break;
- case "left_bottom":
- $.o.out.css({
- "bottom":0,
- "left":0,
- "width": xw + 'px',zIndex:$.o.s.index
- });
- break;
- case "top_middle":
- $.o.out.css({
- "top":"0",
- "left":"50%",
- "marginLeft": '-' + parseInt((xw / 2),10) + 'px',
- "width": xw + 'px',zIndex:$.o.s.index
- });
- break;
- case "right_top":
- $.o.out.css({
- "top":0,
- "right":0,
- "width": xw + 'px',zIndex:$.o.s.index
- });
- break;
- case "right_middle":
- $.o.out.css({
- "top":"50%",
- "right":0,
- "width": xw + 'px',zIndex:$.o.s.index
- });
- if ( !($.browser.msie && $.browser.version < 7)) { // 兼容IE6
- $.o.out.css({marginTop: '-' + parseInt((xh / 2),10) + 'px'});
- }
- break;
- case "right_bottom":
- $.o.out.css({
- "bottom":0,
- "right":0,
- "width": xw + 'px',zIndex:$.o.s.index
- });
- break;
- case "bottom_middle":
- $.o.out.css({
- "bottom":"0",
- "left":"50%",
- "marginLeft": '-' + parseInt((xw / 2),10) + 'px',
- "width": xw + 'px',zIndex:$.o.s.index
- });
- break;
- default:
- $.o.out.css({
- "top":"50%",
- "left":"50%",
- "marginLeft": '-' + parseInt((xw / 2),10) + 'px',
- "width": xw + 'px',zIndex:$.o.s.index
- });
- if ( !($.browser.msie && $.browser.version < 7)) { // 兼容IE6
- $.o.out.css({marginTop: '-' + parseInt((xh / 2),10) + 'px'});
- }
- break;
- }
- return $.o.out;
- };
- $.skygqbox.hide = function(){
- if($.o.ele && $.o.out.size() && $.o.bg.size()){
- $.o.ele.clone(true).appendTo($("body")).hide();
- $.o.out.fadeOut("fast", function(){
- $(this).remove();
- });
- $.o.bg.fadeOut("fast", function(){
- $(this).remove();
- });
- }
- return false;
- };
- $.fn.skygqbox.Default = {
- title : "对话框",
- shut : "关闭",
- index : 2000,
- opacity : 0.5,
- width : "auto",
- height : "auto",
- autoClose : 0,//弹出层等待多长时间自动关闭(单位:毫秒) 0或者负数不触发自动关闭
- position : "middle"
- };
- })(jQuery);
|