linux社区爱心援助Linux认证系列教程业界动态站务新闻公司招聘建议留言网址大全LPI专题CISCO专题
设为首页
加入收藏
管理团队
JSP  
JAVA  
PERL  
 您的位置:首页 > 开发语言 > JavaScript >
栏目导栏
  php
  JSP
  ASP
  asp.net
  JAVA
  c/c++/c#
  perl
  JavaScript
  Basic
  Delphi
资料搜索
热门文章
·javascript 时间对象的格式化
·去掉字符串前后的空格
·javascript 事件调用顺序
·javascript 事件监听机制
·js刷新框架子页面的七种方法
·用javascript操作word文档
·JavaScript:替换字符串
·IE下的JScript编程需注意的内存
·Javascript中CTRL+回车提交表单
·JS 获取鼠标位置
·javascript判断Email地址是否有
·JS实现的滑动展开与折叠效果
·连续滚动图片的制作
·有分页功能的WEB打印
·Javascript中Select的OnChange
最新文章
·使用CSS改变表格边框样式
·为网页添加浮动广告
·判断表单中添加是否数字的JS与
·让浏览器状态栏动起来
·使用Javascript制作行间颜色间
·禁止用右键查看源代码
·网页侦测四法
·制作弹出公告窗口
·为网页添加特效
·网页中取消鼠标右键方法大全
·JavaScript 根据屏幕解析度显示
·如何实现浏览器上的右键菜单
·如何制作浮动广告
·让弹出窗口变得“体贴”一些
·JavaScript技巧:让网页自动穿上
Google
 
如何实现浏览器上的右键菜单
[ 作者:  加入时间:2008-02-22 16:15:55  来自:Linux联盟收集整理 ]
今天和大家一起学习一下如何在浏览器中实现类似于应用程序的鼠标右击后出现右键菜单的效果。iMwLinux联盟
iMwLinux联盟
  首先要解决的问题是在怎样的情况鼠标右击不会出现IE的菜单。思路可以有两个,一个是将焦点移开,还有一个就是点在网页的什么地方不会出现右键菜单,而且会响应鼠标点击消息。 iMwLinux联盟
iMwLinux联盟
iMwLinux联盟
  想了想, 总结出的下面几种方法 iMwLinux联盟
iMwLinux联盟
iMwLinux联盟
  1、响应右键消息出一个ALERT框(还有点新鲜的东东没有)。 iMwLinux联盟
iMwLinux联盟
iMwLinux联盟
  2、响应右键消息后弹出一个新的窗口。将初始页的的焦点移开。 iMwLinux联盟
iMwLinux联盟
iMwLinux联盟
  可是经过试验后发现只有窗口出现在鼠标右击的位置时,才会没有浏览器的右键菜单出现。 iMwLinux联盟
iMwLinux联盟
iMwLinux联盟
  3、响应右键消息后弹出一个HTML的对话框。即使用showModalDialog来开启一个HTML对话框。使用这种方式可以让右键菜单不会出现。但是有一个问题是使用使用showModalDialog开启的对话框不会向使用Window.Open开启的对话框一样可以移出屏幕所在的范围。就是说始终可以看见有一个对话框出现在屏幕上。这条路也不能走了。 iMwLinux联盟
iMwLinux联盟
iMwLinux联盟
  4、最后一招了,在Select上进行鼠标右击或左击都不会有反应。那么如果每次鼠标都点在Select上,不就不会出现浏览器的右键菜单了。 iMwLinux联盟
iMwLinux联盟
iMwLinux联盟
iMwLinux联盟
  下面就是一个例子,感兴趣的可以把下面的拷贝成Test.html,就可以看看效果了。 iMwLinux联盟
iMwLinux联盟
iMwLinux联盟
< HTML> iMwLinux联盟
iMwLinux联盟
< title>webjx Test< /title> iMwLinux联盟
iMwLinux联盟
< script> iMwLinux联盟
iMwLinux联盟
var x, y; iMwLinux联盟
iMwLinux联盟
document.onmousemove=moveMouse iMwLinux联盟
iMwLinux联盟
document.onmousedown=click iMwLinux联盟
iMwLinux联盟
iMwLinux联盟
function moveMouse() iMwLinux联盟
iMwLinux联盟
{ iMwLinux联盟
iMwLinux联盟
Layer1.style.left = event.clientX - 2; iMwLinux联盟
iMwLinux联盟
Layer1.style.top = event.clientY - 2; iMwLinux联盟
iMwLinux联盟
} iMwLinux联盟
iMwLinux联盟
function click() iMwLinux联盟
iMwLinux联盟
{ iMwLinux联盟
iMwLinux联盟
if (event.button==2) iMwLinux联盟
iMwLinux联盟
{ iMwLinux联盟
iMwLinux联盟
x = event.clientX; iMwLinux联盟
iMwLinux联盟
y = event.clientY; iMwLinux联盟
iMwLinux联盟
Layer1.style.visibility=""; iMwLinux联盟
iMwLinux联盟
window.setTimeout("showMenu();", 500); iMwLinux联盟
iMwLinux联盟
} iMwLinux联盟
iMwLinux联盟
else iMwLinux联盟
iMwLinux联盟
{ iMwLinux联盟
iMwLinux联盟
HiddenPop(); iMwLinux联盟
iMwLinux联盟
PopMenu.style.visibility=’hidden’; iMwLinux联盟
iMwLinux联盟
} iMwLinux联盟
iMwLinux联盟
iMwLinux联盟
} iMwLinux联盟
iMwLinux联盟
function showMenu() iMwLinux联盟
iMwLinux联盟
{ iMwLinux联盟
iMwLinux联盟
PopMenu.style.left = x- 2; iMwLinux联盟
iMwLinux联盟
PopMenu.style.top = y- 2; iMwLinux联盟
iMwLinux联盟
PopMenu.style.visibility=""; iMwLinux联盟
iMwLinux联盟
HiddenPop(); iMwLinux联盟
iMwLinux联盟
} iMwLinux联盟
iMwLinux联盟
function HiddenPop() iMwLinux联盟
iMwLinux联盟
{ iMwLinux联盟
iMwLinux联盟
Layer1.style.visibility=’hidden’; iMwLinux联盟
iMwLinux联盟
} iMwLinux联盟
iMwLinux联盟
< /script> iMwLinux联盟
iMwLinux联盟
< BODY> iMwLinux联盟
iMwLinux联盟
iMwLinux联盟
在窗口中右击一下看看出什么:) iMwLinux联盟
iMwLinux联盟
< div id=Layer1 style="position:absolute; width:4px; height:4px; z-index:3; visibility: hidden"> iMwLinux联盟
iMwLinux联盟
< select style="width:4">< /select> iMwLinux联盟
iMwLinux联盟
< /div> iMwLinux联盟
iMwLinux联盟
< div id=PopMenu style="position:absolute; width:100px; height:100px; z-index:1; visibility: hidden"> iMwLinux联盟
iMwLinux联盟
< table border=2 width=100 > iMwLinux联盟
iMwLinux联盟
< TH align="center" color="sliver" onclick=""> iMwLinux联盟
iMwLinux联盟
右键菜单 iMwLinux联盟
iMwLinux联盟
< /tH> iMwLinux联盟
iMwLinux联盟
< tr> iMwLinux联盟
iMwLinux联盟
< td> iMwLinux联盟
iMwLinux联盟
click it!:) iMwLinux联盟
iMwLinux联盟
< /td> iMwLinux联盟
iMwLinux联盟
< /tr> iMwLinux联盟
iMwLinux联盟
< /table> iMwLinux联盟
iMwLinux联盟
< /div> iMwLinux联盟
iMwLinux联盟
< /BODY> iMwLinux联盟
iMwLinux联盟
< /HTML> Linux联盟收集整理 ,转贴请标明原始链接,如有任何疑问欢迎来本站Linux论坛讨论
评论】【加入收藏夹】【 】【打印】【关闭
※ 相关链接
 ·自定义右键菜单代码详解  (2008-02-20 18:02:18)
 ·如何在Linux操作系统下添加鼠标右键菜单  (2007-12-03 10:38:39)