MENUBAR菜单的编写

 

<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.0 Transitional//EN"> <html> <head> <title>AgetimeMenu Demo</title> <meta http-equiv="Content-Type" content="text/html; charset=gb2312"> <style> .agetime_bar{ position:absolute;top:0px;left:0px;height:22px;width:100%;border:1px outset;background-color:RGB(212,208,200);z-index:98; } .agetime_barItem{ width:60px;height:20px;border:1px solid RGB(212,208,200);text-align:left;padding-left:10px; background:RGB(212,208,200);color:#000000;font-size:9pt; } .agetime_barItemDown{ width:60px;height:20px;border:1px inset RGB(212,208,200);text-align:left;padding-left:10px; background:#F0F0F0;color:#000000;font-size:9pt; } .agetime_barItemHover{ width:60px;height:20px;border:1 outset;text-align:left;padding-left:10px; background:#F0F0F0;color:#000000;font-size:9pt; } .agetime_pad{ cursor:default;font-size:9pt;width:100%; } .agetime_padItem{ width:100%;height:18px;border:1px solid RGB(212,208,200);text-align:left;padding-left:10px; background:RGB(212,208,200);color:#000000;font-size:9pt; } .agetime_padItemFalse{ padding-left:10px;font-size:9pt; color:#808080; } .agetime_padItemFalseHover{ padding-left:10px;font-size:9pt; color:#808080;background-color:#333366; } .agetime_padItemHover{ width:100%;height:18px;text-align:left;padding-left:10px; background-color:#333366;color:#FFFFFF;font-size:9pt; } .agetime_padItemDown{ width:100%;height:18px;text-align:left;padding-left:10px;border:1px inset; background-color:#9999CC;color:#FFFFFF;font-size:9pt; } .agetime_hr{ border:1px inset; } .agetime_board{ background-color:RGB(212,208,200);border:2px outset; } </style> </head>

 

 

<body> <script language="javascript"> var menu = agetimeMenu("agetime", [    [     ["文件",null,null,true,"打开文件"], //显示文字,方法,命令,状态,状栏显示文字     ["打开",null,null,false,"打开文件"],     ["--"],     ["你好","js","alert('Hello')",true,"一声问候"],     ["新窗口","ABC","about:blank",true,"弹出ABC窗口"],     ["空白",null,"about:blank",true,"在当前窗口显示空白页"]    ],    [     ["编辑",null,null,false,"打开文件"],     ["撤消",null,null,true,"打开文件"],     ["重做",null,null,true,"打开文件"]    ],    [     ["文件","js","alert('无子菜单')",true,"打开文件"]    ] ] ); //方法为"js"时,命令则为javascript语句,为非"js"值时,命令则是一个URL,而打开这个URL的目标位置则是方法所指定的窗口; //["你好","js","alert('Hello'),true,"一声问候"]; //显示文字为"--"是按钮是一个分隔符;

function agetimeMenu(id,array){ var menu=this; menu.pad=null;     //装载各个子菜单 menu.barItems=[];    //菜单条的各位按钮 menu.pads=[];     //每个子菜单为一个table存放于menu.pad上; menu.selectedIndex=-1; //菜单条选中按钮的索引值 menu.board=null;    //子菜单面板

//建立菜单条 this.crtMenuBar=function(){    var len=array.length;    menu.bar = document.body.appendChild(document.createElement('div'));    menu.bar.className=id+"_bar";    for(var i=0;i<len;i++){     menu.barItems[i]=menu.addMenuBarItem(array[i][0],i);     menu.addMenuPad(array[i],i);    } }

//子菜单 this.addMenuPad=function(ary,index){    var len=ary.length;    var pad=menu.crtElement("table",menu.pad);    pad.cellSpacing=1; pad.cellPadding=0;    pad.className=id+"_pad";

 
 

   pad.style.display="none";    for(var i=1;i<len;i++){     var Row=pad.insertRow(i-1);     menu.addMenuPadItem(ary[i],Row);    }    menu.pads[index]=pad; }

//各子菜单按钮 this.addMenuPadItem=function(ary,Row){     var Cell=Row.insertCell(0);     if(ary[0]!="--"){      Cell.innerText=ary[0];      if(ary[3]){ //有效状态;       Cell.className=id+"_padItem";       Cell.οnmοuseοver=function(){        Cell.className=id+"_padItemHover";        window.status=ary[4];       }       Cell.οnmοuseοut=function(){        Cell.className=id+"_padItem";        window.status="";       }       Cell.οnmοusedοwn=function(){ Cell.className=id+"_padItemDown"; }       Cell.οnmοuseup=function(){        Cell.className=id+"_padItemHover";        menu.hideMenu();        menu.execute(ary);       }      }      else{ //按钮无效;       Cell.className=id+"_padItemFalse";       Cell.οnmοuseοver=function(){        Cell.className=id+"_padItemFalseHover";        window.status=ary[4];       }       Cell.οnmοuseοut=function(){        Cell.className=id+"_padItemFalse";        window.status="";       }      }     }     else{      var hr=menu.crtElement("hr",Cell);      hr.className=id+"_hr";     }     Cell.οnclick=function(){      event.cancelBubble=true;     } }

 

//菜单条的按钮 this.addMenuBarItem=function(ary,index){    var item=menu.crtElement("button",menu.bar);    item.value=ary[0];    item.disabled=!ary[3];    item.className=id+"_barItem";    item.οnmοuseοver=function(){     if(menu.selectedIndex==-1){      item.className=id+"_barItemHover";     }     else{      menu.barItems[selectedIndex].className=id+"_barItem";      item.className=id+"_barItemDown";      menu.showMenu(index);     }     window.status=ary[4];    }    item.οnmοuseοut=function(){     if(menu.selectedIndex==-1) item.className=id+"_barItem";     window.status="";    }    item.οnclick=function(){     event.cancelBubble=true;     if(menu.selectedIndex==-1){      item.className=id+"_barItemDown";      menu.showMenu(index);     }     else{      menu.hideMenu();      item.className=id+"_barItemHover";     }     menu.execute(ary);     item.blur();    }    return item; }

//显示子菜单 this.showMenu=function(index){    if(menu.selectedIndex!=-1) menu.pads[selectedIndex].style.display="none";    menu.board.style.pixelLeft=menu.barItems[index].offsetLeft+2;    //menu.board.style.pixelHeight="";    if(menu.pads[index].rows.length>0) menu.board.style.display="";    else menu.board.style.display="none";    menu.pads[index].style.display="";    menu.selectedIndex=index; }

 

//隐藏子菜单 this.hideMenu=function(){    if(menu.selectedIndex==-1) return;    menu.barItems[menu.selectedIndex].className=id+"_barItem";    menu.pads[selectedIndex].style.display="none";    menu.selectedIndex=-1;    menu.board.style.display="none"; }

//执行菜单命令; this.execute=function(ary){    if(ary[2]==null) return;    if(ary[1]=="js") { eval(ary[2]); menu.hideMenu(); }    else if(ary[1]==null || ary[1].toLowerCase=="_self") location.href=ary[2];    else{ var x=window.open(ary[2],ary[1]); x.focus(); } }

//建立子菜单的显示面板 this.crtMenuBoard=function(){    document.write(     "<div id='"+id+"_board' style='position:absolute;width:160px;height:10px;left:0px;top:20px;background-color:#666666;z-index:99;display:none;'>"+      "<div style='position:absolute;width:100%;height:100%;left:0px;top:0px;'>"+       "<iframe id='"+id+"_frame' name='"+id+"_frame' width='100%' height='100%' frameborder='0' scrolling='no'></iframe>"+      "</div>"+      "<div id='"+id+"_pad' style='position:absolute;width:100%;height:100%;left:0px;top:0px;'></div>"+     "</div>"    );    menu.board=document.getElementById(id+"_board");    menu.pad=document.getElementById(id+"_pad");    menu.pad.className=id+"_board";    menu.pad.onselectstart=function(){ return false;} }

//增加对像的一个子元素 this.crtElement=function(el,p){    return p.appendChild(document.createElement(el)); }

//安装菜单; this.setup=function(){    menu.crtMenuBoard();    menu.crtMenuBar();    document.attachEvent("onclick",menu.hideMenu); }

menu.setup(); } </script> </body> </html>

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值