www.gusucode.com > 简洁的js弹出层、弹出框插件及示例代码源码程序 > 简洁的js弹出层、弹出框插件及示例代码/layerv1.5.2/layer-v1.5.2/layer/layer.js
/************************************************************** @Name : layer v1.5.2 弹层组件开发版 @author: 贤心 @date: 2013-06-06 @blog: http://sentsin.com @微博:http://weibo.com/SentsinXu @QQ群:176047238(layUI交流群) @Copyright: Sentsin Xu(贤心) @官网说明:http://sentsin.com/jquery/layer @赞助layer: https://me.alipay.com/sentsin *************************************************************/ ;!function(window, undefined){ var pathType = true, //是否采用自动获取绝对路径。false:将采用下述变量中的配置 pathUrl = '../../lily/lib/layer/', //当前js所在路径,上述变量为false才有效 $, win, ready = { iE6: !-[1,] && !window.XMLHttpRequest, times: 0 }; //获取当前路径 ready.getPath = function(){ var js = document.scripts || $('script'), jsPath = js[js.length - 1].src; return jsPath.substring(0, jsPath.lastIndexOf("/") + 1); }; //载入css ready.load = function(){ pathType && (pathUrl = this.getPath()); var head = $('head')[0], link = document.createElement("link"); link.setAttribute('type', 'text/css'); link.setAttribute('rel', 'stylesheet'); link.setAttribute('href', pathUrl +'skin/layer.css'); head.appendChild(link); }; //默认内置方法。 this.layer = { v : '1.5.2', //版本号 ready: function(callback){ var load = '#layerCss'; return $(load).ready(function(){ callback(); }); }, alert: function(alertMsg , alertType, alertTit , alertYes){ //普通对话框,类似系统默认的alert() return $.layer({ dialog : {msg : alertMsg, type : alertType, yes : alertYes}, title : alertTit, area: ['auto', 'auto'] }); }, confirm: function(conMsg , conYes , conTit , conNo){ //询问框,类似系统默认的confirm() return $.layer({ dialog : {msg : conMsg, type : 4, btns : 2, yes : conYes, no : conNo}, title : conTit }); }, msg: function(msgText , msgTime , msgType , callback){ //普通消息框,一般用于行为成功后的提醒,默认两秒自动关闭 (msgText == '' || msgText == undefined) && (msgText = ' '); (msgTime == undefined || msgTime == '') && (msgTime = 2); return $.layer({ dialog : {msg : msgText, type : msgType}, time : msgTime, title : ['', false], closeBtn : ['', false], end: function(){callback && callback()} }); }, tips: function(html , follow , time , maxWidth, guide, style){ return $.layer({ type : 4, shade : false, time : time, maxWidth : maxWidth, tips : {msg: html, guide: guide, follow: follow, style: style} }) }, load: function(loadTime , loadgif , loadShade){ var border = true; loadgif === 3 && (border = false); return $.layer({ time : loadTime, shade : loadShade, loading : {type : loadgif}, border :[10,0.3,'#000',border], type : 3, title : ['',false], closeBtn : [0 , false] }); } }; var Class = function(setings){ ready.times++; this.index = ready.times; var config = this.config; this.config = $.extend({} , config , setings); this.config.dialog = $.extend({}, config.dialog , setings.dialog); this.config.page = $.extend({}, config.page , setings.page); this.config.iframe = $.extend({}, config.iframe , setings.iframe); this.config.loading = $.extend({}, config.loading , setings.loading); this.config.tips = $.extend({}, config.tips , setings.tips); this.creat(); }; Class.pt = Class.prototype; //默认配置 Class.pt.config = { type: 0, shade: [0.3 , '#000' , true], shadeClose: false, fix: true, move: ['.xubox_title' , true], moveOut: false, title: ['信息' , true], offset: ['200px' , '50%'], area: ['310px' , 'auto'], closeBtn: [0 , true], time: 0, bgcolor: '#fff', border: [10 , 0.3 , '#000', true], zIndex: 19891014, maxWidth: 400, dialog: {btns : 1, btn : ['确定','取消'], type : 3, msg : '', yes : function(index){ layer.close(index);}, no : function(index){ layer.close(index);} }, page: {dom: '#xulayer', html: ''}, iframe: {src: 'http://sentsin.com'}, loading: {type: 0}, tips: {msg: '', follow: '', guide: 0, isGuide: true, style: ['background-color:#FF9900; color:#fff;', '#FF9900']}, success: function(layer){}, //创建成功后的回调 close: function(index){ layer.close(index);}, //右上角关闭回调 end: function(){} //终极销毁回调 }; Class.pt.type = ['dialog', 'page', 'iframe', 'loading', 'tips']; //容器 Class.pt.space = function(html){ var html = html || '', times = this.index, config = this.config, dialog = config.dialog, frame = [ '<div class="xubox_dialog"><span class="xubox_msg xulayer_png32 xubox_msgico xubox_msgtype' + dialog.type + '"></span><span class="xubox_msg xubox_text">' + dialog.msg + '</span></div>', '<div class="xubox_page">'+ html +'</div>', '<iframe allowtransparency="true" id="xubox_iframe" name="xubox_iframe" onload="$(this).removeClass(\'xubox_load\');" class="xubox_iframe" frameborder="0" src="' + config.iframe.src + '"></iframe>', '<span class="xubox_loading xubox_loading_'+ config.loading.type +'"></span>', '<div class="xubox_tips" style="'+ config.tips.style[0] +'"><div class="xubox_tipsMsg">'+ config.tips.msg +'</div><i class="layerTipsG"></i></div>' ], shade = '' , border = '', zIndex = config.zIndex + times, shadeStyle = 'z-index:'+ zIndex +'; background-color:'+ config.shade[1] +'; opacity:'+ config.shade[0] +'; filter:alpha(opacity='+ config.shade[0]*100 +');'; config.shade[2] && (shade = '<div times="'+ times +'" id="xubox_shade' + times + '" class="xubox_shade" style="'+ shadeStyle +'"></div>'); config.zIndex = zIndex; var title = '', closebtn = '', borderStyle = "z-index:"+ (zIndex-1) +"; background-color: "+ config.border[2] +"; opacity:"+ config.border[1] +"; filter:alpha(opacity="+ config.border[1]*100 +"); top:-"+ config.border[0] +"px; left:-"+ config.border[0] +"px;"; config.border[3] && (border = '<div id="xubox_border'+ times +'" class="xubox_border" style="'+ borderStyle +'"></div>'); config.closeBtn[1] && (closebtn = '<a class="xubox_close xulayer_png32 xubox_close' + config.closeBtn[0] +'" href="javascript:;"></a>'); config.title[1] && (title = '<h2 class="xubox_title"><em>' + config.title[0] + '</em></h2>') var boxhtml = '<div times="'+ times +'" showtime="'+ config.time +'" style="z-index:'+ zIndex +'" id="xubox_layer'+ times +'" class="xubox_layer">' + '<div style="background-color:'+ config.bgcolor +'; z-index:'+ zIndex +'" class="xubox_main">' + frame[config.type] + title + closebtn + '<span class="xubox_botton"></span>' + '</div>'+ border + '</div>'; return [shade , boxhtml]; }; //创建骨架 Class.pt.creat = function(){ var that = this , space = '', config = this.config, dialog = config.dialog, title = that.config.title; title.constructor === Array || (that.config.title = [title, true]); title === false && (that.config.title = [title, false]); var page = config.page, body = $("body"), setSpace = function(html){ var html = html || '' space = that.space(html); body.append(space[0]); }; switch(config.type){ case 1: if(page.html !== ''){ setSpace('<div id="xuboxPageHtml">'+ page.html +'</div>'); body.append(space[1]); }else{ if($(page.dom).parents('.xubox_page').length == 0){ setSpace(); $(page.dom).show().wrap(space[1]); }else{ return; } } break; case 2: $('.xubox_iframe')[0] && layer.close($('.xubox_iframe').parents('.xubox_layer').attr('times')); setSpace(); body.append(space[1]); break; case 3: config.title = ['', false]; config.area = ['auto', 'auto']; config.closeBtn = ['', false]; $('.xubox_loading')[0] && layer.close($('.xubox_loading').parents('.xubox_layer').attr('times')); setSpace(); body.append(space[1]); break; case 4: config.title = ['', false]; config.area = ['auto', 'auto']; config.fix = false; config.border = false; $('.xubox_tips')[0] && layer.close($('.xubox_tips').parents('.xubox_layer').attr('times')); setSpace(); body.append(space[1]); $('#xubox_layer' + ready.times).find('.xubox_close').css({top: 5, right: 5}); break; default : config.title[1] || (config.area = ['auto','auto']); $('.xubox_dialog')[0] && layer.close($('.xubox_dialog').parents('.xubox_layer').attr('times')); setSpace(); body.append(space[1]); break; }; var times = ready.times; this.layerS = $('#xubox_shade' + times); this.layerB = $('#xubox_border' + times); this.layerE = $('#xubox_layer' + times); var layerE = this.layerE; this.layerMian = layerE.find('.xubox_main'); this.layerTitle = layerE.find('.xubox_title'); this.layerText = layerE.find('.xubox_text'); this.layerPage = layerE.find('.xubox_page'); this.layerBtn = layerE.find('.xubox_botton'); //设置layer面积坐标等数据 if(config.offset[1].indexOf("px") != -1){ var _left = parseInt(config.offset[1]); }else{ if(config.offset[1] == '50%'){ var _left = config.offset[1]; }else{ var _left = parseInt(config.offset[1])/100 * win.width(); } }; layerE.css({left: _left + config.border[0], width: config.area[0], height: config.area[1]}); config.fix ? layerE.css({top: parseInt(config.offset[0]) + config.border[0]}) : layerE.css({top: parseInt(config.offset[0]) + win.scrollTop() + config.border[0], position: 'absolute'}); //配置按钮 对话层形式专有 if(config.type == 0 && config.title[1]){ switch(dialog.btns){ case 0: that.layerBtn.html('').hide(); break; case 2: that.layerBtn.html('<a href="javascript:;" class="xubox_yes xubox_botton2">'+ dialog.btn[0] +'</a>' + '<a href="javascript:;" class="xubox_no xubox_botton3">'+ dialog.btn[1] + '</a>'); break; default: that.layerBtn.html('<a href="javascript:;" class="xubox_yes xubox_botton1">'+ dialog.btn[0] +'</a>'); } }; if(layerE.css('left') === 'auto'){ layerE.hide(); setTimeout(function(){ layerE.show(); that.reset(times); }, 500); }else{ that.reset(times); } this.callback(); }; //调整骨架 Class.pt.reset = function(times){ var that = this, layerE = this.layerE, config = this.config, page = config.page; that.autoArea(times); config.time <= 0 || that.autoclose(); config.move[1] ? layerE.find(config.move[0]).css({cursor: 'move'}) : layerE.find(config.move[0]).css({cursor: 'auto'}); if(config.title[1]){ ready.iE6 && that.layerTitle.css({width : layerE.outerWidth()}); }else{ config.type != 4 && layerE.find('.xubox_close').addClass('xubox_close1'); }; layerE.attr({'type' : that.type[config.type]}); switch(config.type){ case 1: layerE.find(page.dom).addClass('layer_pageContent'); that.layerPage.css({width: layerE.width()}); config.shade[2] && layerE.css({zIndex: config.zIndex + 1}); config.title[1] && that.layerPage.css({top: that.layerTitle.outerHeight()}); break; case 2: var iframe = layerE.find('.xubox_iframe'), heg = layerE.height(); iframe.addClass('xubox_load').css({width: layerE.width()}); config.title[1] ? iframe.css({top: that.layerTitle.height(), height: heg - that.layerTitle.height()}) : iframe.css({top: 0, height : heg}); ready.iE6 && iframe.attr('src', config.iframe.src); break; case 4 : var fow = $(config.tips.follow), ftop = fow.offset().top, top = ftop - layerE.outerHeight(); var fleft = fow.offset().left, left = fleft, color = config.tips.style[1]; var fHeight = fow.outerHeight(), fWidth = fow.outerWidth(), tipsG = layerE.find('.layerTipsG'); fWidth > config.maxWidth && fow.width(config.maxWidth); if(config.tips.guide === 1){ var offleft = win.width() - left - fWidth - layerE.outerWidth() - 10, top = ftop; if(offleft > 0){ left = left + fow.outerWidth() + 10; tipsG.removeClass('layerTipsL').addClass('layerTipsR').css({'border-right-color': color}); }else{ left = left - layerE.outerWidth() - 10 tipsG.removeClass('layerTipsR').addClass('layerTipsL').css({'border-left-color': color}); } }else{ if(top - win.scrollTop() - 12 <= 0){ top = ftop + fHeight + 10; tipsG.removeClass('layerTipsT').addClass('layerTipsB').css({'border-bottom-color': color}); }else{ top = top - 10; tipsG.removeClass('layerTipsB').addClass('layerTipsT').css({'border-top-color': color}); } } config.tips.isGuide || tipsG.remove(); layerE.css({top: top , left: left}); break; default : this.layerMian.css({'background-color': '#fff'}); if(config.title[1]){ this.layerText.css({paddingTop: 18 + that.layerTitle.outerHeight()}); }else{ layerE.find('.xubox_msgico').css({top : '10px'}); that.layerText.css({marginTop : 12}); } break; }; this.move(); }; //自适应宽高 Class.pt.autoArea = function(times){ var that = this, layerE = that.layerE, config = that.config, page = config.page, layerMian = that.layerMian, layerBtn = that.layerBtn, layerText = that.layerText, layerPage = that.layerPage, layerB = that.layerB, titHeight; if(config.area[0] === 'auto' && layerMian.outerWidth() >= config.maxWidth){ layerE.css({width : config.maxWidth}); } config.title[1] ? titHeight = that.layerTitle.innerHeight() : titHeight = 0; switch(config.type){ case 0: var aBtn = layerBtn.find('a'), outHeight = layerText.outerHeight() + 20; if(aBtn.length > 0){ var btnHeight = aBtn.outerHeight() + 20; }else{ var btnHeight = 0; } break; case 1: var btnHeight = 0, outHeight = $(page.dom).outerHeight(); config.area[0] === 'auto' && layerE.css({width : layerPage.outerWidth()}); if(page.html !== ''){ outHeight = layerPage.outerHeight(); } break; case 3: var load = $(".xubox_loading"), btnHeight = 0; var outHeight = load.outerHeight(); layerMian.css({width: load.width()}); break; }; (config.offset[1] === '50%' || config.offset[1] == '') && (config.type !== 4) ? layerE.css({marginLeft : -layerE.outerWidth()/2}) : layerE.css({marginLeft : 0}); (config.area[1] === 'auto') && layerMian.css({height: titHeight + outHeight + btnHeight}); layerB.css({width: layerE.outerWidth() + 2*config.border[0] , height: layerE.outerHeight() + 2*config.border[0]}); (ready.iE6 && config.area[0] != 'auto') && layerMian.css({width : layerE.outerWidth()}); }; //拖拽层 Class.pt.move = function(){ var that = this, config = this.config, layerMove = that.layerE.find(config.move[0]), layerE, ismove; var moveX, moveY, move, setX = 0, setY = 0; config.move[1] && layerMove.attr('move','ok'); $(config.move[0]).on('mousedown', function(M){ M.preventDefault(); if($(this).attr('move') === 'ok'){ ismove = true; layerE = $(this).parents('.xubox_layer'); var xx = layerE.offset().left, yy = layerE.offset().top, ww = layerE.width() - 6, hh = layerE.height() - 6; if(!$('#xubox_moves')[0]){ $('body').append('<div id="xubox_moves" class="xubox_moves" style="left:'+ xx +'px; top:'+ yy +'px; width:'+ ww +'px; height:'+ hh +'px; z-index:30000000"></div>'); } move = $('#xubox_moves'); moveX = M.pageX - move.position().left; moveY = M.pageY - move.position().top; setX = win.scrollLeft(); layerE.css('position') !== 'fixed' || (setY = win.scrollTop()); } }); $(document).mousemove(function(M){ if(ismove){ M.preventDefault(); var offsetX = M.pageX - moveX; if(layerE.css('position') === 'fixed'){ var offsetY = M.pageY - moveY; }else{ var offsetY = M.pageY - moveY; } //控制元素不被拖出窗口外 if(!config.moveOut){ var setRig = win.width() - move.outerWidth() - config.border[0], setY = win.scrollTop(), setTop = config.border[0] + setY; offsetX < config.border[0] && (offsetX = config.border[0]); offsetX > setRig && (offsetX = setRig); offsetY < setTop && (offsetY = setTop); offsetY > win.height() - move.outerHeight() - config.border[0] + setY && (offsetY = win.height() - move.outerHeight() - config.border[0] + setY) } move.css({left: offsetX, top: offsetY}); } }).mouseup(function(){ if(ismove){ if(parseInt(layerE.css('margin-left')) == 0){ var lefts = parseInt(move.css('left')); }else{ var lefts = parseInt(move.css('left')) + (-parseInt(layerE.css('margin-left'))) } layerE.css('position') === 'fixed' || (lefts = lefts - layerE.parent().offset().left); layerE.css({left: lefts, top: parseInt(move.css('top')) - setY}); move.remove(); } ismove = false; }); }; //自动关闭layer Class.pt.autoclose = function(){ var that = this, time = this.config.time; var maxLoad = function(){ time--; if(time === 0){ layer.close(that.index); clearInterval(that.autotime); } }; this.autotime = setInterval(maxLoad , 1000); }; ready.config = { end : {} }; Class.pt.callback = function(){ this.openLayer(); var that = this, layerE = this.layerE, config = this.config, dialog = config.dialog; this.config.success(layerE); ready.iE6 && this.IE6(); layerE.find('.xubox_close').off('click').on('click', function(e){ e.preventDefault(); config.close(that.index); }); layerE.find('.xubox_yes').off('click').on('click',function(e){ e.preventDefault(); dialog.yes(that.index); }); layerE.find('.xubox_no').off('click').on('click',function(e){ e.preventDefault(); dialog.no(that.index); }); this.layerS.off('click').on('click', function(e){ e.preventDefault(); that.config.shadeClose && layer.close(that.index); }); ready.config.end[this.index] = config.end; }; Class.pt.IE6 = function(){ var that = this, layerE = this.layerE, select = $('select'); var _ieTop = layerE.offset().top; //ie6的固定与相对定位 if(this.config.fix){ var ie6Fix = function(){ layerE.css({top : $(document).scrollTop() + _ieTop}); }; }else{ var ie6Fix = function(){ layerE.css({top : _ieTop}); }; } ie6Fix(); win.scroll(ie6Fix); //隐藏select $.each(select, function(index , value){ var sthis = $(this); if(!sthis.parents('.xubox_layer')[0]){ sthis.css('display') == 'none' || sthis.attr({'layer' : '1'}).hide(); } }); //恢复select this.reselect = function(){ $.each(select, function(index , value){ var sthis = $(this); if(!sthis.parents('.xubox_layer')[0]){ (sthis.attr('layer') == 1 && $('.xubox_layer').length < 1) && sthis.removeAttr('layer').show(); } }); }; }; //给layer对象拓展方法 Class.pt.openLayer = function(){ var that = this; //自适应宽高 layer.autoArea = function(index){ return that.autoArea(index); }; //获取layer当前索引 layer.getIndex = function(selector){ return $(selector).parents('.xubox_layer').attr('times'); }; //获取子iframe的DOM layer.getChildFrame = function(selector){ return $("#xubox_iframe").contents().find(selector); }; //得到iframe层的索引,子iframe时使用 layer.getFrameIndex = function(){ return $('#xubox_iframe').parents('.xubox_layer').attr('times'); }; //iframe层自适应宽高 layer.iframeAuto = function(){ var wh = [this.getChildFrame('body').outerWidth(), this.getChildFrame('body').outerHeight()], lbox = $('#xubox_iframe').parents('.xubox_layer'), ids = lbox.attr('times'), tit = lbox.find('.xubox_title'), titHt = 0; !tit || (titHt = tit.height()); lbox.css({width: wh[0], height: wh[1] + titHt}); tit.css({width: wh[0]}); var bs = -parseInt($('#xubox_border'+ ids).css('left')); $('#xubox_border'+ ids).css({width: wh[0] + 2*bs, height: wh[1] + 2*bs + titHt}); $('#xubox_iframe').css({width: wh[0], height: wh[1]}); }; //关闭layer layer.close = function(index){ var layerNow = $('#xubox_layer' + index), shadeNow = $('#xubox_shade' + index); if(layerNow.attr('type') == that.type[1]){ if(layerNow.find('#xuboxPageHtml')[0]){ layerNow.remove(); }else{ layerNow.find('.xubox_close,.xubox_botton,.xubox_title,.xubox_border').remove(); for(var i = 0 ; i < 3 ; i++){ layerNow.find('.layer_pageContent').unwrap().hide(); } } }else{ !-[1,] && layerNow.find('#xubox_iframe').remove(); layerNow.remove(); } shadeNow.remove(); ready.iE6 && that.reselect(); typeof ready.config.end[index] === 'function' && ready.config.end[index](); delete ready.config.end[index]; }; //关闭加载层,仅loading私有 layer.loadClose = function(){ var parent = $('.xubox_loading').parents('.xubox_layer'), index = parent.attr('times'); layer.close(index); }; //出场内置动画 layer.shift = function(type, rate){ var config = that.config, iE6 = ready.iE6, layerE = that.layerE, cutWth = 0, ww = win.width(), wh = win.height(); (config.offset[1] == '50%' || config.offset[1] == '') ? cutWth = layerE.outerWidth()/2 : cutWth = layerE.outerWidth(); var anim = { t: {top : config.border[0]}, b: {top : wh - layerE.outerHeight() - config.border[0]}, cl: cutWth + config.border[0], ct: -layerE.outerHeight(), cr: ww - cutWth - config.border[0], fn: function(){ iE6 && that.IE6(); } }; switch(type){ case 'left-top': layerE.css({left: anim.cl, top: anim.ct}).animate(anim.t, rate, anim.fn); break; case 'right-top': layerE.css({left: anim.cr, top: anim.ct}).animate(anim.t, rate, anim.fn); break; case 'left-bottom': layerE.css({left: anim.cl, top: wh}).animate(anim.b, rate, anim.fn); break; case 'right-bottom': layerE.css({left: anim.cr, top: wh}).animate(anim.b, rate, anim.fn); break; }; }; layer.setMove = function(){ return that.move(); } }; //主入口 ready.run = function(){ $ = jQuery; win = $(window); this.load(); $.layer = function(deliver){ var o = new Class(deliver); return o.index; }; }; //为支持CMD规范的模块加载器 var require = '../../init/jquery'; //若采用seajs,需正确配置jquery的相对路径。未用可无视此处。 if(typeof define === 'function' && typeof seajs === 'object'){ define([require], function(require, exports, module){ ready.run(); exports.layer = [window.layer, window['$'].layer]; }); }else{ ready.run(); } }(window);