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


Posted in Javascript onSeptember 18, 2015

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

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

运行效果截图如下:

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

在线演示地址如下:

具体代码如下:

<!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程序设计有所帮助。

Javascript 相关文章推荐
UserData用法总结 lanyu出品
Jul 01 Javascript
Javascript图像处理—虚拟边缘介绍及使用方法
Dec 27 Javascript
如何通过javascript操作web控件的自定义属性
Nov 25 Javascript
JavaScript学习小结(7)之JS RegExp
Nov 29 Javascript
一款简单的jQuery图片标注效果附源码下载
Mar 22 Javascript
详解微信小程序入门五: wxml文件引用、模版、生命周期
Jan 20 Javascript
使用express+multer实现node中的图片上传功能
Feb 02 Javascript
jQuery实现动态加载select下拉列表项功能示例
May 31 jQuery
深入理解react-router 路由的实现原理
Sep 26 Javascript
对vue v-if v-else-if v-else 的简单使用详解
Sep 29 Javascript
JavaScript惰性载入函数实例分析
Mar 27 Javascript
基于node+vue实现简单的WebSocket聊天功能
Feb 01 Javascript
JS实现兼容性好,自动置顶的淘宝悬浮工具栏效果
Sep 18 #Javascript
jQuery采用连缀写法实现的折叠菜单效果
Sep 18 #Javascript
JS+CSS实现TreeMenu二级树形菜单完整实例
Sep 18 #Javascript
JS实现黑色大气的二级导航菜单效果
Sep 18 #Javascript
11种ASP连接数据库的方法
Sep 18 #Javascript
jquery实现隐藏在左侧的弹性弹出菜单效果
Sep 18 #Javascript
JS+CSS实现简易实用的滑动门菜单效果
Sep 18 #Javascript
You might like
用PHP实现小型站点广告管理
2006/10/09 PHP
如何在WIN2K下安装PHP4.04
2006/10/09 PHP
PHP分多步骤填写发布信息的简单方法实例代码
2012/09/23 PHP
朋友网关于QQ相关的PHP代码(研究QQ的绝佳资料)
2015/01/26 PHP
jQuery ready函数滥用分析
2011/02/16 Javascript
js内存泄露的几种情况详细探讨
2013/05/31 Javascript
js实现文本框选中的方法
2015/05/26 Javascript
浅谈jquery中的each方法$.each、this.each、$.fn.each
2016/06/23 Javascript
jQuery操作iframe中js函数的方法小结
2016/07/06 Javascript
微信小程序 教程之列表渲染
2016/10/18 Javascript
浅谈jQuery before和insertBefore的区别
2016/12/04 Javascript
vue之nextTick全面解析
2017/05/17 Javascript
vue中路由参数传递可能会遇到的坑
2017/12/07 Javascript
原生js实现移动端触摸轮播的示例代码
2017/12/22 Javascript
vue组件详解之使用slot分发内容
2018/04/09 Javascript
Vue3.x源码调试的实现方法
2019/10/13 Javascript
ElementUI多个子组件表单的校验管理实现
2019/11/07 Javascript
JS使用setInterval计时器实现挑战10秒
2020/11/08 Javascript
vue添加自定义右键菜单的完整实例
2020/12/08 Vue.js
[02:35]DOTA2英雄基础教程 狙击手
2014/01/14 DOTA
python selenium自动上传有赞单号的操作方法
2018/07/05 Python
python使用OpenCV模块实现图像的融合示例代码
2020/04/10 Python
html5仿支付宝密码框的实现代码
2017/09/06 HTML / CSS
台湾演唱会订票网站:StubHub台湾
2019/06/11 全球购物
库存图片、照片、矢量图、视频和音乐:Shutterstock
2021/02/12 全球购物
使用useBean标志初始化BEAN时如何接受初始化参数
2012/02/11 面试题
介绍一下linux的文件权限
2014/07/20 面试题
护理学院专科毕业生求职信
2014/06/28 职场文书
统计专业自荐书
2014/07/06 职场文书
2015年六一儿童节演讲稿
2015/03/19 职场文书
工作犯错保证书
2015/05/11 职场文书
2015年乡镇流动人口工作总结
2015/05/12 职场文书
中秋节祝酒词
2015/08/12 职场文书
考研经验交流会策划书
2015/11/02 职场文书
PHP获取学生成绩的方法
2021/11/17 PHP
【海涛dota解说】一房久违的影魔魂守二连发
2022/04/01 DOTA