javascript+css实现自定义网页右键菜单

 

 

熟悉window操作系统的用户都知道右键菜单(上下文菜单)简洁明了、操作简便, 然而浏览器自带的右键菜单的功能却都是基于网页整页操作,例如“添加到收藏夹”、“查看源文件”、“打印”,很少涉及到网页内容的操作,因此它的实用性并不大。实际上用Javascript+Css可以实现效果相当不错的网页右键菜单,截图如下:

 

图示:网页右键菜单效果图

特点:样式替换+多级菜单+阴影效果

网页右键菜单程序流程图如下:

本程序由一个js文件和aspx文件组成,没有后台CS代码。

js代码如下

     < script type = " text/javascript " >
    
// 禁用右键菜单
    document.oncontextmenu = ContextMenu;
    
// 鼠标右击事件
    function ContextMenu()
    
{
       
//创建两个变量,作为菜单出现的坐标
       var x;
       var y;
       
//获取菜单外部Div(下面简称面板)
       var FramePanel=document.getElementById("FrameDiv");
       
//获取面板宽度和高度
       var PanelWidth=parseInt(FramePanel.style.width.replace("px",""));
       var PanelHeight
=parseInt(FramePanel.style.height.replace("px",""));
       
//获取鼠标坐标
       var MouseX=event.clientX;
       var MouseY
=event.clientY;
       
//获取网页窗口宽度和高度
       var WindowWidth=document.body.offsetWidth;
       var WindowHeight
=document.documentElement.offsetHeight;
       
       
//如果鼠标X坐标+面板宽度>网页窗口宽度,则面板左边显示
       if((MouseX+PanelWidth)>=WindowWidth)
       
{
            x
=MouseX-PanelWidth-20;
       }

       
else
       
{
            x
=MouseX;
       }

        
//如果鼠标Y坐标+面板高度>网页窗口高度,则面板上边显示
       if((MouseY+PanelHeight)>=WindowHeight)
       
{
            y
=MouseY-PanelHeight-20;
       }

       
else
       
{
            y
=MouseY;
       }

  
       
//显示面板
       FramePanel.style.left=x;
       FramePanel.style.top
=y;
       FramePanel.style.display
="block";
       
       
//隐藏二级菜单
       document.getElementById("ChildDiv").style.display="none";
       
       
return false;//这句代码即等于event.returnValue=false;
    }

    
    
// 鼠标选择该菜单,参数说明:arg为该菜单Div,imageUrl指要替换的image地址,hasChildMenu指该菜单是否有子菜单,childPanelId指子菜单ID(如果有子菜单的话)
  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 3
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值