常使用的前端技巧整理- 弹窗插件(三)

常使用的前端技巧整理- 弹窗插件(三)

前言

基于前面一篇关于弹窗插件的功能不够完善,不是很符合我们公司大多数人的使用习惯,今天又将其重新写了一下,基本思路是参照layer弹出层组件来写的,只保留了部分我们自己平时项目中常用的几个功能。

使用实例

open(el,o) 平时用的最多的,打开一个页面内dom结构但是隐藏(display:none)了的弹窗,$.lay.open('#pop1'); 如果要关闭他,直接使用$.lay.close(); 或者 $.lay.close('#pop1');
***这另种方法的区别在于前者为关闭所有已经打开的弹窗,而后者只关闭指定弹窗;
msg(c,o) 消息提示 $.lay.msg('提示文案')
load(t,o) 加载中提示 $.lay.load(1);
alert(o) 弹窗提示 $.lay.alert({title:'提示一下',content:'这是提示的内容'});
close(index) 关闭全部弹窗 $.lay.close(); 关闭指定弹窗 $.lay.close(el); 或者 $.lay.close(index);
closeLast() 关闭最后一个弹窗 $.lay.closeLast();

方法即参数说明

//弹出层插件使用方法:
// $.lay对象主要包含msg、load、alert、open、close、closeLast这几个方法;
// 其中msg、load、alert、open调用后都会返回一个值,这个值可以用使用.close(index)方法来关闭该值对应的弹出层
// msg(c,o): c-要提示的文本,o-{shade: 0.4,opacity: 0.65,time: 2000,bgColor:‘rgba(0,0,0,1)’},参数设置,shade为遮罩层透明度,opacity弹出层的透明度,time消失的时间(ms),弹出层的背景颜色
// load(t,o): t-loading层的风格(可选值0,1,2), o-{shade: 0,time: false},参数设置 time设置为false时不自动关闭,设置为数字时,表示time秒后自动关闭,
// alert(o): o-{shade:0.6,title:‘提示’,content:’’,close: function () { console.log(‘默认的关闭按钮回调’) }} 其中的close为点击关闭时的回调
// open(el,o): el-为jq选择器的dom对象(支持css、id等所有jq对象),o-{shade: 0.6}
// close(index): 如果index为空,则关闭全部所有弹出层,如果index为dom对象,则关闭指定的弹出层,如果index为由lay打开的弹层的返回值,则关闭指定值的弹出层;
// closeLast(): 关闭最后打开的弹出层

源码

//弹出层插件使用方法:
      //  $.lay对象主要包含轻提示msg、load、alert、open、close、closeLast
      //  其中msg、load、alert、open调用后都会返回一个值,这个值可以用使用.close(index)方法来关闭该值对应的弹出层
      //  msg(c,o): c-要提示的文本,o-{shade: 0.4,opacity: 0.65,time: 2000,bgColor:'rgba(0,0,0,1)'},参数设置,shade为遮罩层透明度,opacity弹出层的透明度,time消失的时间(ms),弹出层的背景颜色
      //  load(t,o): t-loading层的风格(可选值0,1,2), o-{shade: 0,time: false},参数设置 time设置为false时不自动关闭,设置为数字时,表示time秒后自动关闭,
      //  alert(o): o-{shade:0.6,title:'提示',content:'',close: function () { console.log('默认的关闭按钮回调') }} 其中的close为点击关闭时的回调
      //  open(el,o): el-为jq选择器的dom对象(支持css、id等所有jq对象),o-{shade: 0.6}
      //  close(index): 如果index为空,则关闭全部所有弹出层,如果index为dom对象,则关闭指定的弹出层,如果index为由lay打开的弹层的返回值,则关闭指定值的弹出层;
      //  closeLast(): 关闭最后打开的弹出层
      $.extend($, {
        "lay": function() {
          var base_zIndex = 19870906;

          //重新定位弹窗位置
          //con为jq选择器对象:弹窗主体
          function pos(con){
            con.css({
              position:'fixed',
              left: ($(window).width() - con.width()) / 2,
              top: ($(window).height() - con.height()) / 2,
            });
          }
          var ret = {
              index: 0,
              init: !1,
              msg: function (t, o) {
                $('[lay-type="load"],[lay-type="msg"],[lay-type="alert"]').remove(); //先关闭还未关闭的所有的load以及对应的遮罩层
                t = (t || t == '') ? t : '轻轻地提示。。。';
                o = $.extend({shade: 0.4, opacity: 0.65, time: 2000, bgColor: 'rgba(0,0,0,1)'}, o);
                //创建一个
                var index = ++this.index,
                  con = $('<div />').addClass('lay-msg').attr({
                    'times': index,
                    'lay-type': 'msg'
                  }).css({
                    'opacity': 0,
                    'background-color': o.bgColor,
                    'z-index': (base_zIndex + index)
                  }).html(t),
                  shade = $('<div />').addClass('lay-shade').attr({
                    'times': index,
                    'lay-type': 'msg'
                  }).css({'opacity': o.shade, zIndex: (base_zIndex + index)});
                $('body').append(shade).append(con);
                pos(con);
                con.css({opacity: 1});

                //显示以后自动消失
                window.setTimeout(function () {
                  console.log('序号为', index, '的弹出层消失')
                  $('[times="' + index + '"]').css({'opacity': 0});
                  setTimeout(function () {
                    $('[times="' + index + '"]').remove();
                  }, 500);
                }, o.time)
                return index;
              },
              load: function (t, o) {
                $('[lay-type="load"],[lay-type="msg"],[lay-type="alert"]').remove(); //先关闭还未关闭的所有的load以及对应的遮罩层
                t = t ? t : 0;
                o = $.extend({shade: 0, time: false}, o);  //自动关闭时间:如果设定了自动消失的时间,则设定的时间后,自动隐藏,如果没有设置,则需要手动关闭

                //创建一个
                var index = ++this.index
                  , con = $('<div />').addClass('lay-load lay-load-' + t).attr({
                  'times': index,
                  'lay-type': 'load'
                }).css({display: 'block', 'opacity': 0, zIndex: (base_zIndex + index)})
                  , shade = $('<div />').addClass('lay-shade').attr({
                  'times': index,
                  'lay-type': 'load'
                }).css({'opacity': o.shade, zIndex: (base_zIndex + index)});
                $('body').append(shade).append(con);
                pos(con);
                con.css({opacity: 1});

                if (isNaN(o.time)) {
                  window.setTimeout(function () {
                    $('[times]').css({'opacity': 0}) && $('.lay-shade').css({'opacity': 0});
                    setTimeout(function () {
                      $('[times]').remove() && $('.lay-shade').remove();
                    }, 500);
                  }, o.time)
                }
                return index;
              },
              alert: function (o) {
                $('[lay-type="load"],[lay-type="msg"],[lay-type="alert"]').remove(); //先关闭还未关闭的所有的load以及对应的遮罩层
                o = $.extend({shade: 0.6, title: '提示', content: '', close: function () {console.log('默认的关闭按钮回调');}}, o);
                var index = ++this.index;
                // el接受选择器以及字符串
                var shade = $('<div />').addClass('lay-shade').attr({'times': index,'lay-type': 'load'}).css({'opacity': o.shade, 'z-index': (base_zIndex + index)}),
                  con = $('<div />').addClass('lay-alert').attr({'times': index,'lay-type': 'alert'}).css({'opacity': 0, 'z-index': (base_zIndex + index)}),
                  popHead = $('<div />').addClass('lay-alert-head').html(o.title),
                  popBody = $('<div />').addClass('lay-alert-body').html(o.content),
                  popBtnClose = $('<a />').addClass('lay-btn-close').attr({
                    'times-close': index,
                    'href': 'javascript:',
                  }).html('&times;');
                con.append(popHead);
                con.append(popBody);
                con.append(popBtnClose);
                $('body').append(shade).append(con);
                pos(con);
                con.css({opacity: 1});
                $('body').css({'overflow': 'hidden'});
                $(window).on('resize orientationchange', function () {
                  pos(con);
                  setTimeout(function () {
                    pos(con);
                  }, 300);
                });

                $(con).on('click', '.lay-btn-close', function () {
                  var timesClose = $(this).attr('times-close');
                  console.log('关闭', timesClose);
                  $.lay.close(timesClose);
                  o.close();
                });
                return index;
              },
              open: function (el, o) {
                if ($(el).length < 1) { return; }
                o = $.extend({shade: 0.6,more:false}, o);
                $('[lay-type="load"],[lay-type="msg"],[lay-type="alert"]').remove();
                if(!o.more){
                  //是否允许弹出多个层,先关闭还未关闭的所有的load以及对应的遮罩层
                  $('[times]').each(function (idx, it) {
                    ($(it).hasClass('lay-shade') || $(it).hasClass('lay-msg') || $(it).hasClass('lay-load') || $(it).hasClass('lay-alert') || $(it).hasClass('lay-open')) && $(it).remove() || $(it).hide();
                  });
                }
                var index = ++this.index;
                var con = $(el),
                  shade = $('<div />').addClass('lay-shade').attr({'times': index,'lay-type': 'open'})
                  .css({'display': 'block', 'opacity': o.shade, zIndex: (base_zIndex + index)});
                con.attr({'times': index, 'lay-type': 'open'}).css({display: 'block','opacity': 0,zIndex: (base_zIndex + index)});
                shade.insertBefore(con);
                pos(con);
                con.css({opacity: 1})
                $(window).on('resize orientationchange', function () {
                  pos(con);
                  setTimeout(function () {
                    pos(con);
                  }, 300);
                });
                $('body').css({'overflow': 'hidden'});
                return index;
              },
              closeLast: function () {
                $('body').css({'overflow': ''})
                console.log(this.index);
                this.close(this.index);
                return;
              },
              close: function (index) {
                var el = (index===undefined) ?$('[times]') : (isNaN(index) ? $(index) : $('[times="' + index + '"]')   );
                el.css({'transition-duration': '0.2s', 'opacity': 0, 'z-index': '-1'});
                setTimeout(function () {
                  el.each(function (idx, it) {
                    ($(it).hasClass('lay-shade') || $(it).hasClass('lay-msg') || $(it).hasClass('lay-load') || $(it).hasClass('lay-alert')) && $(it).remove() || $(it).hide();
                  });
                }, 300);
                $('body').css({'overflow': ''})
                return;
              }
            },
            init = function () {
              //创建需要用到的样式,只有第一次调用时才加载样式
              !ret.init && $('body').append($('<style type="text/css">' +
                '.lay-shade{transition: opacity 0.3s; position: fixed; width:100%; height: 100%; top:0; left:0; z-index: 999; background: rgba(0,0,0);}' +
                '.lay-alert{max-width:90%; transition: opacity 0.5s; position: fixed; width:300px; min-height: 160px; top:0; left:0; z-index: 1000; border-radius: 6px; box-shadow: 0 0 8px rgba(0,0,0,.1); background: rgba(255,255,255,1); }' +
                '.lay-alert-head{font-size: 14px; font-weight: bold; line-height: 36px; padding:0 10px; background: #F2F2F2; border-radius: 5px 5px 0 0;}' +
                '.lay-alert-body{min-height: 160px;}' +
                '.lay-btn-close{width:34px; height: 34px; font-size: 30px; text-align: center; line-height: 30px; color:#333; text-shadow: rgba(0,0,0,.5); position: absolute; right:0; top:0px;}' +
                '.lay-msg{transition: opacity 0.3s; position: fixed; width:auto; height: auto; max-width:80%; word-break: break-all; top:0; left:0; padding:12px 25px; font-size: 14px; color: #fff; z-index: 1000;' +
                ' box-shadow: 0 0 8px rgba(0,0,0,.1);  border-radius: 3px;}' +
                '.lay-load{transition: opacity 0.5s; position: fixed; width:auto; height: auto; top:0%; left:0; z-index: 1000;}' +
                '.lay-load-0{width:60px; height: 24px; background: url() no-repeat; background-size: 60px 24px; }' +
                '.lay-load-1{width:37px; height: 37px; background: url() no-repeat; background-size: 37px 37px; }' +
                '.lay-load-2{width:32px; height: 32px; background: url() no-repeat; background-size: 32px 32px; }' +
                '</style>')) && (ret.init = !ret.init);
            }();
          return ret;
        }(),
        //注意:一下只是常用工具,弹窗插件并不依赖一下工具函数
        "tools": {
          browser: {
            versions: function () {
              var u = window.navigator.userAgent;
              return {
                trident: u.indexOf('Trident') > -1, //IE内核
                presto: u.indexOf('Presto') > -1, //opera内核
                webKit: u.indexOf('AppleWebKit') > -1, //苹果、谷歌内核
                gecko: u.indexOf('Gecko') > -1 && u.indexOf('KHTML') == -1, //火狐内核
                mobile: !!u.match(/AppleWebKit.*Mobile.*/) || !!u.match(/AppleWebKit/), //是否为移动终端
                ios: !!u.match(/\(i[^;]+;( U;)? CPU.+Mac OS X/), //ios终端
                android: u.indexOf('Android') > -1 || u.indexOf('Linux') > -1, //android终端或者uc浏览器
                iPhone: u.indexOf('iPhone') > -1 || u.indexOf('Mac') > -1, //是否为iPhone或者安卓QQ浏览器
                iPad: u.indexOf('iPad') > -1, //是否为iPad
                webApp: u.indexOf('Safari') == -1,//是否为web应用程序,没有头部与底部
                weixin: u.indexOf('MicroMessenger') > -1, //是否为微信浏览器
                qq: u.indexOf('mqqbrowser') > -1 && u.indexOf(" qq") < 0,
                qqInstalled: u.indexOf(' qq') > -1 && u.indexOf('mqqbrowser') < 0,
              };
            }(),
            isQQWx: function () {
              var u = window.navigator.userAgent;
              return (u.indexOf('MicroMessenger') > -1 || u.indexOf('mqqbrowser') > -1 && u.indexOf(" qq") < 0 || u.indexOf(' qq') > -1 && u.indexOf('mqqbrowser') < 0)
            }()
          },
          isJson: function (obj) {
            //判断是否为json对象
            var isjson = typeof(obj) == "object" && Object.prototype.toString.call(obj).toLowerCase() == "[object object]" && !obj.length;
            return isjson;
          },
          getParam: function (variable) {
            //获取链接中指定参数的值
            var query = window.location.search.substring(1);
            var vars = query.split("&");
            for (var i = 0; i < vars.length; i++) {
              var pair = vars[i].split("=");
              if (pair[0] == variable) {
                return pair[1];
              }
            }
            return (false);
          },
          getRequest:function GetRequest() {
            //获取连接中的参数,并返回一个json对象
            var url = location.search; //获取url中"?"符后的字串
            var theRequest = new Object();
            if (url.indexOf("?") != -1) {
              var strs = url.substr(1).split("&");
              for (var i = 0; i < strs.length; i++) { theRequest[strs[i].split("=")[0]] = unescape(strs[i].split("=")[1]); }
            }
            return theRequest;
          },
          getHost:function() {
            //获取域名地址
            return window.location.protocol + '//' +
              window.location.host;
          }(),
          stampToTime: function (stamp) {
            //13位数字的时间戳转为时间对象
            var d = new Date(stamp);
            return {
              d: d,
              YY: d.getFullYear(),
              MM: d.getMonth() + 1,
              DD: d.getDate(),
              hh: d.getHours(),
              mm: d.getMinutes(),
              ss: d.getSeconds(),
            };
          },
          getRnd: function (num1, num2) {
            switch (arguments.length) {
              case 1:
                return Math.floor(Math.random() * arguments[0] + 1);     //返回0-max的随机整数
              case 2:
                var min = arguments[0],max = arguments[1];
                if (arguments[0] - arguments[1] > 0) { min = arguments[1]; max = arguments[0];}
                return Math.floor(Math.random() * (max - min + 1) + min);      //返回min-max的随机整数
              default:
                return 0;
            }
          }
        }
      },true)
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值