轻量级网页遮罩层jQuery插件用法实例


Posted in Javascript onJuly 31, 2015

本文实例讲述了轻量级网页遮罩层jQuery插件用法。分享给大家供大家参考。具体如下:

使用jQuery的好处是很多人为它写一些组件,而在项目所需用到功能也都可以找到一些组件去完成。

现在又这样一个需求当用户点击一个按钮后不允许用户进行任何的操作,取而代之的是弹出一个遮罩层显示一个loading提示框,效果如下。

轻量级网页遮罩层jQuery插件用法实例

其实这个需求很简单,但很多组件体积相对这个需求来说太大了,在网上瞎溜达了找到了一个还不错的组件,作者是上面也没有写。现在就来分析一下这个组件的源码和使用

/**
 * @部分参数说明
 */
(function($){
 $.fn.extend({
  //主函数
  toggleLoading: function(options){
      // 找到遮罩层
    var crust = this.children(".x-loading-wanghe");
      // 当前操作的元素
      var thisjQuery = this;
      // 实现toogle(切换遮罩层出现与消失)效果的判断方法
    if(crust.length>0){
      if(crust.is(":visible")){
        crust.fadeOut(500);
      }else{
        crust.fadeIn(500);
      }
      return this;
    }
   // 扩展参数
   var op = $.extend({
    z: 9999,
    msg:'数据加载中...',
    iconUrl:'images/loading.gif',
    width:18,
    height:18,
    borderColor:'#6bc4f5',
    opacity:0.5,
        agentW:thisjQuery.outerWidth(),
        agentH:thisjQuery.outerHeight()
   },options);
   if(thisjQuery.css("position")=="static")
     thisjQuery.css("position","relative");
   //var w = thisjQuery.outerWidth(),h = thisjQuery.outerHeight();
   var w = op.agentW,h = op.agentH;
   crust = $("<div></div>").css({//外壳
    'position': 'absolute',
    'z-index': op.z,
    'display':'none',
    'width':w+'px',
    'height':h+'px',
    'text-align':'center',
    'top': '0px',
    'left': '0px',
    'font-family':'arial',
    'font-size':'12px',
    'font-weight':'500'
   }).attr("class","x-loading-wanghe");
   var mask = $("<div></div>").css({//蒙版
    'position': 'absolute',
    'z-index': op.z+1,
    'width':'100%',
    'height':'100%',
    'background-color':'#333333',
    'top': '0px',
    'left': '0px',
    'opacity':op.opacity
   });
   //71abc6,89d3f8,6bc4f5
   var msgCrust = $("<span></span>").css({//消息外壳
      'position': 'relative',
        'top': (h-30)/2+'px',
      'z-index': op.z+2,
      'height':'24px',
      'display':'inline-block',
      'background-color':'#cadbe6',
      'padding':'2px',
      'color':'#000000',
      'border':'1px solid '+op.borderColor,
      'text-align':'left',
      'opacity':0.9
     });
   var msg = $("<span>"+op.msg+"</span>").css({//消息主体
       'position': 'relative',
       'margin': '0px',
      'z-index': op.z+3,
      'line-height':'22px',
      'height':'22px',
      'display':'inline-block',
      'background-color':'#efefef',
      'padding-left':'25px',
      'padding-right':'5px',
      'border':'1px solid '+op.borderColor,
      'text-align':'left',
      'text-indent':'0'
     });
      var msgIcon = $("<img src="+op.iconUrl+" />").css({//图标
      'position': 'absolute',
      'top': '3px',
      'left':'3px',
      'z-index': op.z+4,
      'width':'18px',
      'height':'18px'
     });  
      // 拼装遮罩层
   msg.prepend(msgIcon);
    msgCrust.prepend(msg);
    crust.prepend(mask);
    crust.prepend(msgCrust);
   thisjQuery.prepend(crust);
     // alert(thisjQuery.html());
   crust.fadeIn(500);
   //模态设置
   return this;
  }
 });
})(jQuery);

相关配置

配置&configure


全部配置 默认值 说明
z: 9999 图层z-index,当蒙版遮罩不住时候适当增大其值
msg: 数据加载中... 提示信息
iconUrl: images/loading.gif 提示图片url
height: 18 图标默认高(px)
width: 18 图标默认宽(px)
borderColor #6bc4f5 提示的边框颜色
opacity: 0.5 蒙版的透明度
agentW: 当前元素的宽度 蒙版的宽度
agentH: 当前元素的高度 蒙版的高度

希望本文所述对大家的jquery程序设计有所帮助。

Javascript 相关文章推荐
禁止js文件缓存的代码
Apr 09 Javascript
深入理解JavaScript系列(8) S.O.L.I.D五大原则之里氏替换原则LSP
Jan 15 Javascript
javascript简单事件处理和with用法介绍
Sep 16 Javascript
escape函数解决js中ajax传递中文出现乱码问题
Oct 30 Javascript
window.onload使用指南
Sep 13 Javascript
JS实现按比例缩放图片的方法(附C#版代码)
Dec 08 Javascript
详解AngularJS Filter(过滤器)用法
Dec 28 Javascript
Bootstrap Table从零开始
Jun 30 Javascript
详解React native fetch遇到的坑
Aug 30 Javascript
微信小程序下拉刷新PullDownRefresh的使用方法
Nov 29 Javascript
详解使用webpack+electron+reactJs开发windows桌面应用
Feb 01 Javascript
解决nuxt页面中mounted、created、watch执行两遍的问题
Nov 05 Javascript
js实时获取并显示当前时间的方法
Jul 31 #Javascript
Javascript实现的Map集合工具类完整实例
Jul 31 #Javascript
JS特效实现图片自动播放并可控的效果
Jul 31 #Javascript
javascript实现列表滚动的方法
Jul 30 #Javascript
百度地图API之本地搜索与范围搜索
Jul 30 #Javascript
javaScript实现滚动新闻的方法
Jul 30 #Javascript
javascript中递归函数用法注意点
Jul 30 #Javascript
You might like
PHP学习之PHP运算符
2006/10/09 PHP
php读取30天之内的根据算法排序的代码
2008/04/06 PHP
php 正则 过滤html 的超链接
2009/06/02 PHP
PHP入门教程之数学运算技巧总结
2016/09/11 PHP
php opendir()列出目录下所有文件的实例代码
2016/10/02 PHP
thinkPHP框架中layer.js的封装与使用方法示例
2019/01/18 PHP
用javascript实现给出的盒子的序列是否可连为一矩型
2007/08/30 Javascript
php与js的区别是什么
2013/08/05 Javascript
jquery.post用法示例代码
2014/01/03 Javascript
利用JavaScript检测CPU使用率自己写的
2014/03/22 Javascript
jQuery $命名冲突解决方案汇总
2014/11/13 Javascript
关于编写性能高效的javascript事件的技术
2014/11/28 Javascript
jQuery实现购物车数字加减效果
2015/03/14 Javascript
原生js和jquery实现图片轮播淡入淡出效果
2015/04/23 Javascript
Css3制作变形与动画效果
2015/07/24 Javascript
基于javascript实现页面加载loading效果
2020/09/15 Javascript
js实现上传图片预览方法
2016/10/25 Javascript
微信小程序 chooseImage选择图片或者拍照
2017/04/07 Javascript
详解tween.js 中文使用指南
2018/01/05 Javascript
Vue框架之goods组件开发详解
2018/01/25 Javascript
js中实例与对象的区别讲解
2019/01/21 Javascript
通过实例了解js函数中参数的传递
2019/06/15 Javascript
JS箭头函数和常规函数之间的区别实例分析【 5 个区别】
2020/05/27 Javascript
vue之封装多个组件调用同一接口的案例
2020/08/11 Javascript
Python中列表的一些基本操作知识汇总
2015/05/20 Python
Python tkinter模块中类继承的三种方式分析
2017/08/08 Python
Flask实现图片的上传、下载及展示示例代码
2018/08/03 Python
关于Django ForeignKey 反向查询中filter和_set的效率对比详解
2018/12/15 Python
用xpath获取指定标签下的所有text的实例
2019/01/02 Python
Python3 venv搭建轻量级虚拟环境的步骤(图文)
2019/08/09 Python
Python 生成一个从0到n个数字的列表4种方法小结
2019/11/28 Python
基于python3抓取pinpoint应用信息入库
2020/01/08 Python
adidas官方旗舰店:德国运动用品制造商
2017/11/25 全球购物
体育教师个人总结
2015/02/09 职场文书
小程序实现文字循环滚动动画
2021/06/14 Javascript
新手入门Mysql--概念
2021/06/18 MySQL