Struts项目中右键菜单一般很少用到,但是一旦客户有要求,很多人就懵圈了,比如我。这个时候,当然要表现镇定,一面拍着胸口对客户承诺说绝对可以实现,一面赶紧打开百度神器,搜搜看是否有前人已经写好的插件。

jquery实现右键菜单插件,jquery右键菜单插件

今天开发一个项目的时候需要一个模拟鼠标右键菜单的功能。也就是在网页点击鼠标右键的时候不是弹出系统的菜单而是我们制定的内容。这样可以拓展右键的功能。实现过程不多说了,写出来的代码和效果如下:

js部分:

复制代码 代码如下:
//创建右键菜单
var epMenu={
    create:function(point,option){
        var menuNode=document.getElementById(‘epMenu’);
        if(!menuNode){
            //没有菜单节点的时候创建一个
            menuNode=document.createElement(“div”);
            menuNode.setAttribute(‘class’,’epMenu’);
            menuNode.setAttribute(‘id’,’epMenu’);
        }else $(menuNode).html(”);//清空里面的内容
       
        $(menuNode).css({left:point.left+’px’,top:point.top+’px’});
        for(var x in option){
            var tempNode=document.createElement(“a”);
           
$(tempNode).text(option[x][‘name’]).on(‘click’,option[x].action);
            menuNode.appendChild(tempNode);
        }
       
        $(“body”).append(menuNode);
    },
    destory:function(){
        $(“.epMenu”).remove();
    }   
};

css部分代码如下:

复制代码 代码如下:
/*右键菜单*/
.epMenu{ width:120px; background:#f0f0f0; position:fixed; left:0;
top:0; box-shadow:2px 2px 2px 2px #807878;}
.epMenu a{ display:block; height:25px; line-height:25px;
padding-left:15px; border-top:1px solid #e0e0e0; border-bottom:1px
solid #fff; font-family:微软雅黑; font-size:14px; cursor:default;}
.epMenu a:hover{ background:#fff;}

创建调用代码如下:

复制代码 代码如下:
epMenu.create({left:500,top:500},[{name:’a1′,’action’:addText},{name:’b222′,’action’:addBtn},{name:’添加图片组件’,’action’:addImage}]);

销毁调用代码如下:

复制代码 代码如下:
epMenu.destory();

效果如下:

图片 1

调用说明:

创建:epMenu.create(point,option);

point   整数型,表示菜单的位置,相对浏览器左上角。

          示例:{left:100, top:500}

option json数组型,表示菜单项,name表示名称,action表示点击激发的动作。

         
示例:[{name:’a1′,’action’:addText},{name:’b222′,’action’:addBtn},{name:’添加图片组件’,’action’:addImage}]

销毁:epMenu.destory();

销毁不需要参数。

这玩意其实很简单!还可以扩展一下,比如添加图片,二级菜单等等。由于这次项目开发需求比较简单,就这么的吧。

以上所述就是本文的全部内容了,希望大家能够喜欢。

今天开发一个项目的时候需要一个模拟鼠标右键菜单的功能。也就是在网页点击鼠标右键的时候…

于是便找到了jQuery的ContextMenu插件。上官网看看Demo,真不错,正是我要的效果。源码下下来,却没有说明文档告诉我们该如何组装,可能写这插件的牛人们觉得步骤太简单,写出来都觉得丢人。可苦了我们这等愚昧之徒,研究半天,总算从一堆代码中取其精华弃其糟粕,形成最简练的代码,以供初学者们参考。

官网下载地址:

我这边下的是1.6.6版本。源码目录结构如下:

图片 2

里边有个demo.html文件,这个就是我们要研究的对象。打开这个文件,可以试试效果,感觉不错吧。

图片 3

但是用记事本或者其他编辑器查看源代码,你会觉得头晕。一堆的js文件和css文件,恐怖不是每个都是必须的,这就要我们自己调试了,插件作者是不会告诉我们的。

图片 4

OK,由于时间关系,我已经帮大家删掉多余的代码,精简后的代码如下:

<html>
<head>
  <title>jQuery contextMenu Plugin Demo</title>

  <script src="jquery-1.8.2.min.js" type="text/javascript"></script>
  <script src="src/jquery.contextMenu.js" type="text/javascript"></script>
  <link href="src/jquery.contextMenu.css" rel="external nofollow" rel="stylesheet" type="text/css" />

</head>

<body>

<div class="context-menu-one">
  <strong>right click me</strong>
</div>

<script type="text/javascript" class="showcase">
$(function(){
  $.contextMenu({
    selector: '.context-menu-one', 
    callback: function(key, options) {
      var m = "clicked: " + key;
      window.console && console.log(m) || alert(m); 
    },
    items: {
      "edit": {name: "Edit", icon: "edit"},
      "cut": {name: "Cut", icon: "cut"},
      "copy": {name: "Copy", icon: "copy"},
      "paste": {name: "Paste", icon: "paste"},
      "delete": {name: "Delete", icon: "delete"},
      "sep1": "---------",
      "quit": {name: "Quit", icon: "quit"}
    }
  });

  $('.context-menu-one').on('click', function(e){
    console.log('clicked', this);
  })
});
</script>

</body>
</html>

发表评论

电子邮件地址不会被公开。 必填项已用*标注

网站地图xml地图