jQuery实现仿人人网弹出层效果
创始人
2024-07-24 16:10:41
0

有兴趣的朋友可以从文章最顶部的链接下载js文件。下面的代码是我所拓展的部分。在这分隔线之前基本上没有多少改动。

  1. 1 //---------------------------------------blockUI part end-----------------------------------  
  2.  2 //change blockUI default settings  
  3.  //change blockUI border  
  4.  $.blockUI.defaults.css.border = '5px solid #ccc';      //边框样式  
  5.  $.blockUI.defaults.css.cursor = 'default';                 //鼠标样式  
  6.  $.blockUI.defaults.css.top = '20%';                        //弹出层的位置  
  7.  $.blockUI.defaults.css.left = '30%';                          
  8.  $.blockUI.defaults.overlayCSS.cursor = 'default';  
  9.  //change fadeOut effact speed  
  10.  $.blockUI.defaults.fadeOut = 100;    //淡入淡出效果的速度  
  11.  $.blockUI.defaults.fadeIn = 100;  
  12.     

//上面这一部分主要功能是修改弹出层的默认样式

//----------==================================华丽的分割线================================---

  1. //blockUI extend function  
  2. //以下三个方法在页面调用时,给点按钮或者文字添加onlick事件调用  
  3. //Confirm Delete or any other events  
  4. //1,该方法弹出带有确认与取消两个按钮的层,点击确认触发clickEvent()方法  
  5. $.confirm = function(settings) {  
  6.     var htmlDom = $("
");  
  •     htmlDom.css({ "text-align": "center", "vertical-align": "middle", "line-height": "70px" });  
  •     var msg = $("
  • " + settings.msg + "
  • class=\"standard-button\" value=\"取消\" onclick=\"javascript:closeBlockUINoFresh();\" 
  •  style=\"margin-right:20px;\"/>");  
  •     htmlDom.append(msg);  
  •     msg.find('#confirmButton').click(settings.clickEvent);  
  •     $.blockUI({  
  •         message: htmlDom,  
  •         css: { width: "650px", height: "70px", "background-color": "#fff" }  
  •     });  
  •     pressEscOut();  
  • }  
  •    
  • jQuery

    这个截图就是上面的confrim()方法的效果。有一个确认按钮,然后有一个取消按钮。

    调用也很简单

    1. $(function(){  
    2.       var settings={  
    3.        msg:"确认删除选中的记录?",  //要在弹出层上显示的消息  
    4.        clickEvent:function(){  
    5.          //do something              此处是给确定按钮绑定方法  
    6.       }}  
    7.       $.confirm(settings);         //此处调用方法,然后把上面的定义的settings对象做为参数传入   
    8.  });   
    9.  

    上面这个方法点击取消或者确认按钮后页面是无刷新的,但是有时候操作之后需要刷新页面那就用下面这个方法,调用方法跟上面的一致,只是方法名变了而已。

    1. $.confirmWithRefresh = function(settings) {  
    2.      var htmlDom = $("
    ");  
  •      htmlDom.css({ "text-align": "center", "vertical-align": "middle", "line-height": "70px" });  
  •      var msg = $("
  • width=\"100%\">"
  •  + settings.msg + "
  • id=\"confirmButton\" />
  • class=\"standard-button\" id=\"cancelButton\" value=\"取消\" onclick=\"javascript:closeBlockUINoFresh();
  • \" style=\"margin-right:20px;\"/>");  
  •      htmlDom.append(msg);  
  •      msg.find('#confirmButton').click(settings.clickEvent);  
  •      $.blockUI({  
  •          message: htmlDom,  
  •          css: { width: "650px", height: "70px", "background-color": "#fff" }  
  •      });  
  •      pressEscOut();  
  •  }  
  •  //对于有些页面关闭层时不需要刷新页面,所以采用不同的关闭方式  
  •  $.confirmNoRefresh = function(settings) {  
  •      var htmlDom = $("
  • ");  
  •      htmlDom.css({ "text-align": "center", "vertical-align": "middle", "line-height": "70px" });  
  •      var msg = $("
  • " + settings.msg + "
  • id=\"close\" class=\"standard-button\" id=\"cancelButton\" value=\"取消\" 
  • onclick=\"javascript:closeBlockUINoFresh();\" style=\"margin-right:20px;\"/>");  
  •      htmlDom.append(msg);  
  •      msg.find('#confirmButton').click(settings.clickEvent);  
  •      $.blockUI({  
  •          message: htmlDom,  
  •          css: { width: "650px", height: "70px", "background-color": "#fff" }  
  •      });  
  •      pressEscOut();  
  •  }   
  •  
    1. //弹出提示框  
    2. $.prompt = function(settings) {  
    3.     var htmlDom = $("
    ");  
  •     htmlDom.css({ "text-align": "center", "vertical-align": "middle", "line-height": "70px" });  
  •     htmlDom.append("
  • " + settings.msg + "
  • onclick=\"javascript:closeBlockUINoFresh();\"/>");  
  •     $.blockUI({  
  •         message: htmlDom,  
  •         css: { width: "550px", height: "70px", "background-color": "#fff", "z-index": settings.baseZ }  
  •     });  
  •     pressEscOut();  
  • }     
  • jQuery

    上面的方法只是提示作用,显示一个消息。这比alert()可好看多了吧

    调用方法

    $.prompt({msg:"删除成功"});

    下面的方法就是刷新页面的了

    1. $.promptWithRefresh = function(settings) {  
    2.      var htmlDom = $("
    ");  
  •      htmlDom.css({ "text-align": "center", "vertical-align": "middle", "line-height": "70px" });  
  •      htmlDom.append("
  • " + settings.msg + "
  • onclick=\"javascript:closeBlockUI();\" />");  
  •      $.blockUI({  
  •          message: htmlDom,  
  •          css: { width: "550px", height: "70px", "background-color": "#fff", "z-index": settings.baseZ }  
  •      });  
  •      pressEscOut();  
  •  }  
  •  $.promptWithRefreshOverride = function(settings) {  
  •      var htmlDom = $("
  • ");  
  •      htmlDom.css({ "text-align": "center", "vertical-align": "middle", "line-height": "70px" });  
  •      var msg = $("
  • " + settings.msg + "
  • ");  
  •      htmlDom.append(msg);  
  •      msg.find('#Confirm').click(settings.clickEvent);  
  •      $.blockUI({  
  •          message: htmlDom,  
  •          css: { width: "550px", height: "70px", "background-color": "#fff", "z-index": settings.baseZ }  
  •      });  
  •      pressEscOut();  
  •  }  
  •  //弹出提示框无刷新  
  •  $.promptNoRefresh = function(settings) {  
  •      var htmlDom = $("
  • ");  
  •      htmlDom.css({ "text-align": "center", "vertical-align": "middle", "line-height": "70px" });  
  •      htmlDom.append("
  • " + settings.msg + "
  • onclick=\"javascript:closeBlockUINoFresh();\" />");  
  •      $.blockUI({  
  •          message: htmlDom,  
  •          css: { width: "550px", height: "70px", "background-color": "#fff", "z-index": settings.baseZ }  
  •      });  
  •      pressEscOut();  
  •  } 
  • //该方法弹出添加或者修改的层,调用时需要传一个DOM以及层的标题。方法分别是formTitle(),appendTable(),且该方法有确认与取消两个按钮,确认按钮事件需要在页面js中重写方法是clickEvent()

    1. $.msgBox = function(settings) {  
    2.      var tempScreen = (document.body.clientWidth - settings.width.replace("px", "")) / 2;  
    3.      var htmlDom = $("
    ");  
  •      var msg = $("
  • style=\"vertical-align:top;width:100%\">
  • font-size:14px;padding-left:15px;padding-top:10px;padding-bottom:10px;background-color:#3777bc;
  • vertical-align:middle;color:#fff;font-weight:bold\">" + settings.title + "
  • background-color:#3777bc;vertical-align:middle;cursor:pointer;color:#fff;font-weight:bold\"
  •  onclick=\"javascript:closeBlockUINoFresh();\">关闭
  •  style=\"text-align:center;width:100%\">" + settings.dom + "
  •   
  • value=\"取消\" onclick=\"javascript:closeBlockUINoFresh();\"/>");  
  •      htmlDom.append(msg);  
  •      msg.parent().find('#confirmButton').click(settings.clickEvent);  
  •      $.blockUI({  
  •          message: htmlDom,  
  •          css: { width: settings.width, "background-color": "#fff", "z-index": settings.baseZ, left: tempScreen }  
  •      });  
  •      pressEscOut();  
  •  }  
  • 这个方法就比较强大了,可以传一个dom进来。

    jQuery

    看着挺像人人网的弹出层吧,样式确实是模仿的人人网的。

    调用方法也还是先定义一个对象。给属性赋值.属性有哪些看看上面的代码中settings.xxxx 这xxxxx就是属性。还可以根据自己的需要去添加,或者减少。

    1. var settings={   
    2. title:"添加用户",          //标题   
    3. width:"600px",   
    4. clickEvent:function(){  
    5.  
    6.    //do something   
    7. }   
    8. $.msgBox(settings);  
    1. //该方法弹出添加或者修改的层,调用时需要传一个DOM以及层的标题。方法分别是formTitle(),appendTable(),
    2. 且该方法有确认与取消两个按钮,确认按钮事件需要在页面js中重写方法是clickEvent()  
    3.  $.msgBoxWithRefresh = function(settings) {  
    4.      var tempScreen = (document.body.clientWidth - settings.width.replace("px", "")) / 2;  
    5.      var htmlDom = $("
    ");  
  •      var msg = $("
  •  class=\"innderTable\" style=\"vertical-align:top;width:100%\">
  • font-size:14px;padding-left:15px;padding-top:10px;padding-bottom:10px;background-color:#3777bc;
  • vertical-align:middle;color:#fff;font-weight:bold\">" + settings.title + "
  • background-color:#3777bc;vertical-align:middle;cursor:pointer;color:#fff;font-weight:bold\" 
  • onclick=\"javascript:closeBlockUINoFresh();\">关闭
  • style=\"text-align:center;width:100%\">" + settings.dom + "
  •  style=\"text-align:right;padding-right:10px;padding-bottom:10px;\">
  •   
  • onclick=\"javascript:closeBlockUINoFresh();\"/>");  
  •      htmlDom.append(msg);  
  •      msg.parent().find('#confirmButton').click(settings.clickEvent);  
  •      $.blockUI({  
  •          message: htmlDom,  
  •          css: { width: settings.width, "background-color": "#fff", "z-index": settings.baseZ, left: tempScreen }  
  •      });  
  •      pressEscOut();  
  •  }  
  •  //关闭blcokUI,该方法为默认方法,不需要变动。  
  •  function closeBlockUI() {  
  •      $.unblockUI();  
  •      location.reload();  
  •      return false;  
  •  }  
  •  //关闭blockUI但不刷新页面  
  •  function closeBlockUINoFresh() {  
  •      $.unblockUI();  
  •  }  
  •  function pressEscOut() {  
  •      $("*").keypress(function(event) {  
  •          var jianzhi = event.keyCode;  
  •          var input_keydown = $(this);  
  •          switch (jianzhi) {  
  •              case 27:  
  •                  closeBlockUINoFresh();  
  •                  break;  
  •          }  
  •      });  
  •  }    
  •    
  •  
  • 注明一下哈:虽然原本的插件不是本人原创,但拓展方法本人确实花了些心思。

    原文链接:http://www.cnblogs.com/think_fish/archive/2011/03/30/1999506.html

    【编辑推荐】

    1. 27个新鲜惊奇的jQuery插件与教程
    2. 手把手教你用jQuery做动画插件
    3. PHP+MySQL+jQuery实现随意拖动层
    4. jQuery拖动布局实现排序结果同步数据库
    5. jQuery给力插件大阅兵

    上一篇:三种直接备份WordPress博客数据库的方法

    下一篇:徐少春:金蝶要打造“中国管理云”

    相关内容

    热门资讯

    如何允许远程连接到MySQL数... [[277004]]【51CTO.com快译】默认情况下,MySQL服务器仅侦听来自localhos...
    如何利用交换机和端口设置来管理... 在网络管理中,总是有些人让管理员头疼。下面我们就将介绍一下一个网管员利用交换机以及端口设置等来进行D...
    施耐德电气数据中心整体解决方案... 近日,全球能效管理专家施耐德电气正式启动大型体验活动“能效中国行——2012卡车巡展”,作为该活动的...
    Windows恶意软件20年“... 在Windows的早期年代,病毒游走于系统之间,偶尔删除文件(但被删除的文件几乎都是可恢复的),并弹...
    20个非常棒的扁平设计免费资源 Apple设备的平面图标PSD免费平板UI 平板UI套件24平图标Freen平板UI套件PSD径向平...
    德国电信门户网站可实时显示全球... 德国电信周三推出一个门户网站,直观地实时提供其安装在全球各地的传感器网络检测到的网络攻击状况。该网站...
    为啥国人偏爱 Mybatis,... 关于 SQL 和 ORM 的争论,永远都不会终止,我也一直在思考这个问题。昨天又跟群里的小伙伴进行...
    《非诚勿扰》红人闫凤娇被曝厕所... 【51CTO.com 综合消息360安全专家提醒说,“闫凤娇”、“非诚勿扰”已经被黑客盯上成为了“木...