jquery插件ContextMenu设置右键菜单


Posted in Javascript onMarch 13, 2017

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

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

官网下载地址:http://plugins.jquery.com/contextMenu/

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

jquery插件ContextMenu设置右键菜单

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

jquery插件ContextMenu设置右键菜单

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

jquery插件ContextMenu设置右键菜单

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>

运行效果:

jquery插件ContextMenu设置右键菜单

根据这段精简后的代码,我们就可以知道使用这个插件了。

第一步:把核心文件jquery-1.8.2.min.js、jquery.contextMenu.js、jquery.contextMenu.css拷贝至我们的项目中。

第二步:编写生成菜单以及相应菜单动作的javascript脚本。

$(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);
  })
});

第三步:在合适的位置设置右键菜单。

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

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
原生js仿jq判断当前浏览器是否为ie,精确到ie6~8
Aug 30 Javascript
js实现按钮控制图片360度翻转特效的方法
Feb 17 Javascript
jQuery选择器源码解读(六):Sizzle选择器匹配逻辑分析
Mar 31 Javascript
jQuery实现的背景动态变化导航菜单效果
Aug 24 Javascript
极易被忽视的javascript面试题七问七答
Feb 15 Javascript
Angularjs 实现分页功能及示例代码
Sep 14 Javascript
vue 虚拟dom的patch源码分析
Mar 01 Javascript
《javascript少儿编程》location术语总结
May 27 Javascript
js/jquery遍历对象和数组的方法分析【forEach,map与each方法】
Feb 27 jQuery
使用JavaScript通过前端发送电子邮件
May 22 Javascript
解决VUE 在IE下出现ReferenceError: Promise未定义的问题
Nov 07 Javascript
JavaScript使用setTimeout实现倒计时效果
Feb 19 Javascript
jQuery实现表格奇偶行显示不同背景色 就这么简单
Mar 13 #Javascript
轻松实现jQuery添加删除按钮Click事件
Mar 13 #Javascript
jQuery+CSS3实现点赞功能
Mar 13 #Javascript
百度地图JavascriptApi Marker平滑移动及车头指向行径方向
Mar 13 #Javascript
分享一个精简的vue.js 图片lazyload插件实例
Mar 13 #Javascript
常用的几个JQuery代码片段
Mar 13 #Javascript
Vue2.0利用 v-model 实现组件props双向绑定的优美解决方案
Mar 13 #Javascript
You might like
让PHP支持页面回退的两种方法[转]
2007/02/14 PHP
PHP解析html类库simple_html_dom的转码bug
2014/05/22 PHP
Smarty局部缓存的几种方法简介
2014/06/17 PHP
php获取错误信息的方法
2015/07/17 PHP
解决php的“It is not safe to rely on the system’s timezone settings”问题
2015/10/08 PHP
关于Yii2框架跑脚本时内存泄漏问题的分析与解决
2019/12/01 PHP
jQuery源码分析-03构造jQuery对象-源码结构和核心函数
2011/11/14 Javascript
JS阻止用户多次提交示例代码
2014/03/26 Javascript
JS实现控制表格内指定单元格内容对齐的方法
2015/03/30 Javascript
JavaScript中的普通函数与构造函数比较
2015/04/07 Javascript
BootStrap中的Fontawesome 图标
2017/05/25 Javascript
使用 vue 实现灭霸打响指英雄消失的效果附demo
2019/05/06 Javascript
js中arguments对象的深入理解
2019/05/14 Javascript
layer.alert回调函数执行关闭弹窗的实例
2019/09/11 Javascript
Python selenium文件上传方法汇总
2020/11/19 Python
python自带的http模块详解
2016/11/06 Python
python中利用xml.dom模块解析xml的方法教程
2017/05/24 Python
PyQt5每天必学之弹出消息框
2018/04/19 Python
python爬取内容存入Excel实例
2019/02/20 Python
Python GUI编程学习笔记之tkinter界面布局显示详解
2020/03/30 Python
让Django的BooleanField支持字符串形式的输入方式
2020/05/20 Python
Python 解决相对路径问题:&quot;No such file or directory&quot;
2020/06/05 Python
CSS3制作炫酷的自定义发光文字
2016/03/28 HTML / CSS
css3实现六边形边框的实例代码
2019/05/24 HTML / CSS
加拿大女装网上购物:Reitmans
2016/10/20 全球购物
草莓网英国官网:Strawberrynet UK
2017/02/12 全球购物
意大利奢侈品牌在线精品店:Jole.it
2020/11/23 全球购物
大学生毕业自我鉴定范文
2013/11/03 职场文书
新娘父亲婚礼致辞
2014/01/16 职场文书
创业女性典型材料
2014/05/02 职场文书
捐书活动总结
2014/05/04 职场文书
毕业生求职信
2014/06/10 职场文书
银行主办会计岗位职责
2014/08/13 职场文书
安全生产先进个人总结
2015/02/15 职场文书
2016大学生就业指导课心得体会
2016/01/15 职场文书
php实例化对象的实例方法
2021/11/17 PHP