AutoCAD 3DMAX C语言 Pro/E UG JAVA编程 PHP编程 Maya动画 Matlab应用 Android
Photoshop Word Excel flash VB编程 VC编程 Coreldraw SolidWorks A Designer Unity3D
 首页 > JavaScript

JS实现兼容性好,带缓冲的动感网页右键菜单效果

51自学网 http://www.wanshiok.com
JS,缓冲,动感,网页右键菜单

本文实例讲述了JS实现兼容性好,带缓冲的动感网页右键菜单效果。分享给大家供大家参考。具体如下:

这是一款兼容好带缓冲的动感网页右键菜单,应该来说做的非常棒,完全JavaScript的实现,我觉得挺不错,感谢作者。

运行效果截图如下:

在线演示地址如下:

http://demo.wanshiok.com/js/2015/js-dg-right-button-menu-style-codes/

具体代码如下:

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN""http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"><html xmlns="http://www.w3.org/1999/xhtml"><head><meta http-equiv="Content-Type" content="text/html; charset=gb2312" /><title>右键菜单</title><style type="text/css">div,body,span,ul,li {padding:0;margin:0;font-size:12px;}ul,ol {list-style-type:none;}#div1 {width:196px;height:296px;padding:2px;overflow:hidden;position:absolute;border:1px solid #666;left:200px;top:50px;display:none;z-index=1;-webkit-box-shadow:1px 3px 4px #888;box-shadow:1px 3px 4px #888;-moz-box-shadow:1px 3px 4px #888;}#ul li {width:176px;height:25px;line-height:25px;cursor:pointer;overflow:hidden;padding-left:20px;}.tip {width:500px;height:25px;font-size:20px;margin:50px 200px;color:red;}</style><script type="text/javascript">var g_oDiv={};var oDiv=null;var g_iSpeed=0;var t=null;window.onload=function(){ opUl(); oDiv=document.getElementById("div1"); oDiv.style.height="0px"; document.oncontextmenu=function(ev){   var oEvent=window.event||ev;   cancelDefault(oEvent);   g_oDiv.MouseX=oEvent.clientX;   g_oDiv.MouseY=oEvent.clientY;   oDiv.style.left=g_oDiv.MouseX+"px";   oDiv.style.top=g_oDiv.MouseY+"px";   /* 初始化经过背景为空 */   var oUl=document.getElementById("ul");   var aLi=oUl.getElementsByTagName("li");   for(var i=0;i<aLi.length;i++){    aLi[i].style.background="none";   }   clearInterval(t);   doDiv(); } document.body.onmousedown=function(ev){  var oEvent=window.event||ev;  clearInterval(t);  g_iSpeed=0;  g_oDiv.h=0;  oDiv.style.height=g_oDiv.h+"px";  oDiv.style.display="none"; } oDiv.onmousedown=function(ev){  var oEvent=window.event||ev;  oEvent.cancelBubble=true; }}function doDiv(ev){ var oEvent=window.event||ev; oDiv.style.display="block"; t=setInterval(doMove,30);}function doMove(){ if(oDiv.offsetHeight>=302){  g_iSpeed*=-0.7;  oDiv.style.height=302+"px"; } g_oDiv.h=g_iSpeed+oDiv.offsetHeight; g_iSpeed+=10;  oDiv.style.height=g_oDiv.h+"px";}function cancelDefault(oEvent){ if(oEvent.preventDefault){  oEvent.preventDefault(); } else{  oEvent.returnValue=false; }}/* 对li操作后的动作的定义 */function opUl(){ var oUl=document.getElementById("ul"); var aLi=oUl.getElementsByTagName("li"); for(var i=0;i<aLi.length;i++){  aLi[i].aIndex=i;  aLi[i].onmouseover=function(){   for(j=0;j<aLi.length;j++){    aLi[j].style.background="none";   }   aLi[this.aIndex].style.background="#ffbb66";  }  aLi[i].onclick=function(){   clearInterval(t);   oDiv.style.display="none";   alert(this.innerHTML+" 你可以在这里自定义自己的方法啦");  } }}</script></head><body style="width:2000px;height:800px;"><div class="tip">右键点击游览器呗</div> <div id="div1">  <ul id="ul">   <li>这是第一行</li>   <li>这是第二行</li>   <li>这是第三行</li>   <li>这是第四行</li>   <li>这是第五行</li>   <li>这是第六行</li>   <li>这是第一行</li>   <li>这是第二行</li>   <li>这是第三行</li>   <li>这是第四行</li>   <li>这是第五行</li>   <li>这是第六行</li>  </ul> </div></body></html>

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


JS,缓冲,动感,网页右键菜单  
上一篇:JS实现的不规则TAB选项卡效果代码  下一篇:JS实现兼容性好,自动置顶的淘宝悬浮工具栏效果