JS实现兼容性好,带缓冲的动感网页右键菜单效果
网络编程 2021-07-04 21:03www.168986.cn编程入门
这篇文章主要介绍了JS实现兼容性好,带缓冲的动感网页右键菜单效果,可实现带有弹性效果并且能够自定义鼠标事件的右键菜单功能,具有一定参考借鉴价值,需要的朋友可以参考下
本文实例讲述了JS实现兼容性好,带缓冲的动感网页右键菜单效果。分享给大家供大家参考。具体如下:
这是一款兼容好带缓冲的动感网页右键菜单,应该来说做的非常棒,完全JavaScript的实现,我觉得挺不错,感谢作者。
运行效果截图如下:
在线演示地址如下:
具体代码如下:
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://.w3./TR/xhtml1/DTD/xhtml1-transitional.dtd"> <html xmlns="http://.w3./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;: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.=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程序设计有所帮助。
编程语言
- 机械手焊接机器人编程 机械手焊接设备编程
- vb数据库编程实例,vb做数据库
- tiobe世界编程语言排行榜,全球编程语言排行
- 成都java编程培训 成都it编程培训中心
- 编程基础培训,编程基础知识培训
- flash游戏编程基础教程,flash游戏开发教程
- 不会英语能学编程吗 不会英语可以学程序员吗
- 爱心代码编程C语言 爱心代码编程c语言公式
- c语言编程学习入门 c语言编程快速入门
- 西门子plc编程培训 西门子plc编程培训班
- 哪里可以学编程 台州哪里可以学编程
- 少儿编程哪个好 少儿编程哪个品牌好
- 编程是什么意思,图形编程是什么意思
- c语言编程软件下载,c语言编程软件在哪下载
- java编程软件下载,java编程下载手机版
- ug编程培训学校,ug编程培训教程