zoukankan      html  css  js  c++  java
  • jquery.hovermenu.js

    View Code
      1 /**
    2 + ---------------------------------------- +
    3 + HoverMenu组件v1.0
    4 + Author: zzf
    5 + Date: 2012-3-27
    6 + ---------------------------------------- +
    7 **/
    8 /**
    9 * hovermenu弹出菜单效果
    10 * @name jQuery.HoverMenu
    11 * @param {object} obj 对象形式的参数
    12 * @class
    13 * @return jQuery.HoverMenu instance
    14 */
    15
    16 $.HoverMenu = function(opts) {
    17 //如果在构造实例的时候忘了new,就重新实例化
    18 if (! (this instanceof arguments.callee)) {
    19 return new arguments.callee(opts);
    20 }
    21 //执行类似其他语言的初始化函数,利用apply指定上下文(context)为该实例,并且传入参数
    22 this.init.apply(this, arguments);
    23 }
    24
    25 $.HoverMenu.prototype = function (){
    26 var getZindex=function (){
    27 var ret=0,i=0,temp,tags=$('*'),len=tags.length;
    28 for(; i<len; i++) {
    29 temp=parseInt(tags.eq(i).css('zIndex'));
    30 if (temp>ret) ret=temp;
    31 }
    32 return ret;
    33 },
    34 map={
    35 'mouseenter':'mouseleave',
    36 'show':'hide',
    37 'fadeIn':'fadeOut',
    38 'slideDown':'slideUp',
    39 'toggle':'toggle',
    40 'click':'click',
    41 'mouseover':'mouseout'
    42 };
    43 return{
    44 constructor: $.HoverMenu,
    45 init: function(opts) {
    46 var self=this;
    47 //配置属性
    48 $.extend(this, {
    49 wrap:null, //触发层,必须指定
    50 target:null, //弹出层,必须指定
    51 event: 'mouseenter', //默认事件 hover
    52 position:'b', //相对触发层的位置 l左 r右 t上 b下 默认值为b
    53 offsetX:0, //水平偏移 默认值为0
    54 offsetY:0, //垂直偏移 默认值为0
    55 hideTimeout: 300, //隐藏延迟时间
    56 close:null, //关闭,一般用于click触发的弹出菜单
    57 callback: $.noop, //回调函数
    58 fx:'show', //弹出时的动画效果 默认值为"show"
    59 fxTime:0 //动画效果执行时间 默认值为0
    60 },opts || {});
    61
    62 if (!this.wrap.length || !this.target.length ) return;
    63 if (this.target.is(':visible')) {this.target.hide()};
    64 this.wrap.bind(this.event,function (){self.showMe.call(self)});
    65 if (this.close) {
    66 this.close.live(map[this.event],function (){self.hideMe.call(self,this)});
    67 }else{
    68 this.wrap.bind(map[this.event],function (){self.hideMe.call(self)});
    69 }
    70 },
    71 showMe:function (){
    72 var x=0,
    73 y=0,
    74 $wrap=this.wrap,
    75 $target=this.target,
    76 w=$wrap.outerWidth(),
    77 h=$wrap.outerHeight(),
    78 tw=$target.outerWidth(),
    79 th=$target.outerHeight();
    80
    81 $wrap.css('position')==='static' && $wrap.css('position','relative');
    82 $wrap.css('zIndex',(getZindex()+1));
    83 switch(this.position){
    84 case "l":
    85 x=-w+this.offsetX-1;
    86 y=this.offsetY;
    87 break
    88 case "r":
    89 x=w+this.offsetX;
    90 y=this.offsetY;
    91 break
    92 case "t":
    93 x=this.offsetX;
    94 y=-th+this.offsetY+1;
    95 break
    96 case "b":
    97 default:
    98 x=this.offsetX;
    99 y=h+this.offsetY-1;
    100 }
    101 this.target.css({"position":"absolute","left":x,"top":y}).stop(true,true)[this.fx](this.fxTime);
    102 },
    103 hideMe:function (target){
    104 var self=this;
    105 setTimeout(function (){self.target.stop(true,true)[map[self.fx]](self.fxTime);},this.hideTimeout);
    106 this.callback && this.callback.call($(target));
    107 }
    108 }
    109 }();
    110



    AAA
    触发层,必须指定
    弹出层,必须指定
    触发层,必须指定
    弹出层,必须指定
    触发层,必须指定
    弹出层,必须指定
    触发层,必须指定
    弹出层,必须指定
    触发层,必须指定
    • aaaa
    • bbb
    • ccc
    • ddd
  • 相关阅读:
    使用 RemObjects SDK 建立 WebService 应用
    Excel文件读写的.NET开源组件 Koogra Excel BIFF/XLSX Reader Library
    DataSnap 2009 系列之三 (生命周期篇)
    更改SQL Server表所有者的操作方法
    delphi调用cmd的两种方法
    用AndroidX86和VirtualBox打造高性能Android开发环境
    DevExpress 换肤
    Remobjects关于Channel is Busy 错误的解决方法
    关于D7“System.pas not found”错误的解决方法
    40 套漂亮的图标
  • 原文地址:https://www.cnblogs.com/zhuzf/p/2419966.html
Copyright © 2011-2022 走看看