网站建设| 数据库类| 图形图象| 程序设计| 现代办公| 操作系统| 考试认证| 网络技术| 软件工程| 电脑相关| 文学作品
网站开发| 网页制作| 操作系统| 图象图形| 考试认证| 数据库类| 程序设计| 硬件技术| 现代办公| 网络技术| 笑话频道
 
您的位置: 电脑书库首页-> 电脑文摘-> 网站开发-> 其它-> javascript中如何实现浏览器上的右键菜单

javascript中如何实现浏览器上的右键菜单
作者:佚名 来源:InterNet 加入时间:2005-4-3
相关文章
  • 在javascript中调用vbscript的函数,构造一个javascript版的trim 函数
  • javascript表单之间的数据传递
  • 一个简单的javascript菜单
  • 一组JavaScript绘图函数
  • asp自动生成javascript检验函数
  • 用JavaScript实现利用FLASH嵌入声音
  • Javascript设计漫天雪花
  • Javascript模拟游戏中的弹出菜单效果
  • 利用JAVASCRIPT制作简单动画
  • 首页地址添加到收藏夹(javascript)
  • 相关书籍:
  • JavaScript 权威指南(第四版)
  • JavaScript傻瓜指南
  • 最近在程序员大本营中的讨论中有一位老兄提出如何在浏览器中实现类似于应用程序的鼠标右击后出现右键菜单的效果。唯鱼试了试,发现不是很难解决。现在就将源码和原理说出来和大家共享一下。哈,其实效果不是很完美啦,如果哪位大侠有更好的解决方法。可以给唯鱼yyu@enet.com.cn来信罗。

      首先要解决的问题是在怎样的情况鼠标右击不会出现IE的菜单。思路可以有两个,一个是将焦点移开,还有一个就是点在网页的什么地方不会出现右键菜单,而且会响应鼠标点击消息。(哈哈,废话一大堆。思路吗?总要多想想才有的)

    想了想, 总结出的下面几种方法

    1、响应右键消息出一个ALERT框(还有点新鲜的东东没有)。

    2、响应右键消息后弹出一个新的窗口。将初始页的的焦点移开。

    可是经过试验后发现只有窗口出现在鼠标右击的位置时,才会没有浏览器的右键菜单出现。

    3、响应右键消息后弹出一个HTML的对话框。即使用showModalDialog来开启一个HTML对话框。使用这种方式可以让右键菜单不会出现。但是有一个问题是使用使用showModalDialog开启的对话框不会向使用Window.Open开启的对话框一样可以移出屏幕所在的范围。就是说始终可以看见有一个对话框出现在屏幕上。这条路也不能走了。

    4、呵呵,最后一招了,唯鱼偶尔发现在Select上进行鼠标右击或左击都不会有反应。那么如果每次鼠标都点在Select上,不就不会出现浏览器的右键菜单了。

     

    下面就是一个例子,感兴趣的可以把下面的拷贝成Test.html,就可以看看效果了。

    < HTML>

    < title>VFish Test< /title>

    < script>

    var x, y;

    document.onmousemove=moveMouse

    document.onmousedown=click

    function moveMouse()

    {

    Layer1.style.left = event.clientX - 2;

    Layer1.style.top = event.clientY - 2;

    }

    function click()

    {

    if (event.button==2)

    {

    x = event.clientX;

    y = event.clientY;

    Layer1.style.visibility="";

    window.setTimeout("showMenu();", 500);

    }

    else

    {

    HiddenPop();

    PopMenu.style.visibility=’hidden’;

    }

    }

    function showMenu()

    {

    PopMenu.style.left = x- 2;

    PopMenu.style.top = y- 2;

    PopMenu.style.visibility="";

    HiddenPop();

    }

    function HiddenPop()

    {

    Layer1.style.visibility=’hidden’;

    }

    < /script>

    < BODY>

    在窗口中右击一下看看出什么:)

    < div id=Layer1 style="position:absolute; width:4px; height:4px; z-index:3; visibility: hidden">

    < select style="width:4">< /select>

    < /div>

    < div id=PopMenu style="position:absolute; width:100px; height:100px; z-index:1; visibility: hidden">

    < table border=2 width=100 >

    < TH align="center" color="sliver" onclick="">

    唯鱼的菜单

    < /tH>

    < tr>

    < td>

    click it!:)

    < /td>

    < /tr>

    < /table>

    < /div>

    < /BODY>

    < /HTML>


    [文章录入员:nancy]

    相关文章
  • 在javascript中调用vbscript的函数,构造一个javascript版的trim 函数
  • javascript表单之间的数据传递
  • 一个简单的javascript菜单
  • 一组JavaScript绘图函数
  • asp自动生成javascript检验函数
  • 用JavaScript实现利用FLASH嵌入声音
  • Javascript设计漫天雪花
  • Javascript模拟游戏中的弹出菜单效果
  • 利用JAVASCRIPT制作简单动画
  • 首页地址添加到收藏夹(javascript)
  • 相关书籍:
  • JavaScript 权威指南(第四版)
  • JavaScript傻瓜指南
  • 本站推荐内容

    近期主机类热搜关键词:
    美国服务器 美国服务器租用 海外服务器租用 国外服务器租用

    其它
    ASP/ASP.NET
    PHP技术
    JSP技术
    XML技术
    CGI/PERL
    WEB服务器
    WordPress专题
    其它
    电脑教程阅读排行
    ·VBScript 函数集
    ·关于SQL语句中的引号问题(VB...
    ·网站建设步骤
    ·网上建站论坛的选择和安装(菜鸟版...
    ·用ASP动态生成JavaScri...
    ·Apache+PHP+MySQL...
    ·用VBScript实现对Wind...
    ·VBScript和JavaScr...
    ·在javascript中调用vb...
    ·一个简单的javascript菜...