[xPlugins] jQuery Contextmenu右键菜单
[2012-04-12] Contextmenu 右键菜单 v0.1 版本发布
[功能] 在特定区域弹出右键菜单
[功能] 可以在弹出右键菜单区域内,再屏蔽某个小区域。
[功能] 有两种方式添加右键菜单项,参数配置添加和指定ID项。
[功能] 支持事件回调,有两种,一种以参数配置方式对应回调,指定ID项统一回调,可根据设置链接标签区别。
[2012-04-29]Contextmenu 右键菜单 v0.2版本更新
[修正] 修正了指定ID添加内容在不存在时的bug。
[新增] 新增了菜单失效后变成灰色,事件回调失效的功能。
[调整] 调整了部分css,源代码分为模型,和调试部分。
插件说明
Contextmenu 是一款基于 jQuery 的多功能对话框插件。
运行环境
兼容 IE6+、Firefox、Chrome、Opera 等主流浏览器。
使用授权
Contextmenu 永久免费使用,如果有好的建议,请 Email: atlatl333@126.com , Contextmenu 的完善需要大家的好建议。
由于配置整体项目开发要用到右键菜单,比如表格,web桌面等。介绍右键菜单设计有哪些功能,可以根据配置文件注释得知。
- var defaults={
- offsetX:2,//鼠标在X轴偏移量
- offsetY:2,//鼠标在Y轴偏移量
- speed:300,//特效速度
- flash:!1,//特效是否开启,默认不开启
- flashMode:'',//特效模式,与flash为真时使用
- cancel:!1,//排除不出现右键菜单区域
- items:[],//菜单项
- action:$.noop()//自由菜单项回到事件
- };
关于右键菜单的添加有两种方式: 一种是以items项添加并直接带有事件回调;
- <script type="text/javascript">
- $(function(){
- $('#WincontextMenu-Test').WinContextMenu({
- cancel:'.cancel',
- items:[{
- id:'Item1',
- text:'Item1项',
- icon:'../skins/default/contextmenu/icons/Sync.png',
- disable:!0,//新增加true/false
- action:function(){alert('first-item1')}//按照项添加
- },
- {
- id:'Item2',
- text:'Item2项',
- icon:'../skins/default/contextmenu/icons/Calendar.png',
- action:function(){alert('Second-item2')}//按照项添加
- }],
- action:function(e){alert(e.id);}//自由设计项事件回调
- });
- });
- </script>
第二种在web页面中按指定的ID为WincontextMenu添加li标记
- <div id="WincontextMenu" class="WincontextMenu" style="top:100px; left:230px; display:none;">
- <li><a id="copy" href="#"><img src="../skins/default/contextmenu/icons/Copy.png"><span>复制</span></a></li>
- <li><a id="create" href="#"><img src="../skins/default/contextmenu/icons/New.png"><span>新建</span></a></li>
- <div class="m-split"></div>
- <li><a id="save" href="#"><img src="../skins/default/contextmenu/icons/Save.png"><span>保存</span></a></li>
- <li><a id="table" href="#" class="cmDisable"><img src="../skins/default/contextmenu/icons/table.png"><span>表格</span></a></li>
- <li><a id="setup" href="#"><img src="../skins/default/contextmenu/icons/Pinion.png"><span>设置</span></a></li>
- </div>
以上两种添加方式是以items项添加在前,按指定ID追加的排在后。
百闻不如一见,还是直接奔源代码去……本页面有下载。
[文件] AdminInterface-Contextmenu(源码v0.2).rar ~ 268KB 下载(34)


- /*
- * Author:antianlu
- * Date:2012-04-21
- * Plugin name:jQuery.Contextmenu
- * Address:http://www.oschina.net/code/snippet_153403_9880
- * Version:0.2
- * Email:atlatl333@126.com
- */
- (function(cm){
- jQuery.fn.WinContextMenu=function(options){
- var defaults={
- offsetX:2,//鼠标在X轴偏移量
- offsetY:2,//鼠标在Y轴偏移量
- speed:300,//特效速度
- flash:!1,//特效是否开启,默认不开启
- flashMode:'',//特效模式,与flash为真时使用
- cancel:!1,//排除不出现右键菜单区域
- items:[],//菜单项
- action:$.noop()//自由菜单项回到事件
- };
- var opt=cm.extend(true,defaults,options);
- function create(e){
- var m=cm('<ul class="WincontextMenu"></ul>').appendTo(document.body);
- cm.each(opt.items,function(i,itm){
- if(itm){
- var row=cm('<li><a class="'+(itm.disable?'cmDisable':'')+'" ref="sitem" href="javascript:void(0)"><span></span></a></li>').appendTo(m);
- itm.icon?cm('<img src="'+itm.icon+'">').insertBefore(row.find('span')):'';
- itm.text?row.find('span').text(itm.text):'';
- if(itm.action) {
- row.find('a').click(function(){this.className!='cmDisable'?itm.action(e):null;});}
- }
- });
- if(cm('#WincontextMenu').html()!=null){
- cm(cm('#WincontextMenu').html().replace(/#/g,'javascript:void(0)')).appendTo(m);}
- return m;
- }
- if(opt.cancel){//排除不出现右键菜单区域
- cm(opt.cancel).live('contextmenu',function(e){return false});}
- this.live('contextmenu',function(e){
- var m=create(e).show();
- var l = e.pageX + opt.offsetX,
- t = e.pageY+opt.offsetY,
- p={
- wh:cm(window).height(),
- ww:cm(window).width(),
- mh:m.height(),
- mw:m.width()
- }
- t=(t+p.mh)>=p.wh?(t-=p.mh):t;//当菜单超出窗口边界时处理
- l=(l+p.mw)>=p.ww?(l-=p.mw):l;
- m.css({zIndex:1000001, left:l, top:t}).live('contextmenu', function() { return false; });
- m.find('a').click(function(e){//呼叫新从页面增加的菜单项
- var b=$(this).attr('ref');
- if(b!='sitem'){this.className!='cmDisable'?opt.action(this):null;}
- e.preventDefault();
- });
- cm(document.body).live('contextmenu click', function() {//防止有动态加载的标签失效问题
- m.remove();
- });
- return false;
- });
- return this;
- }
- })(jQuery);
原文地址:http://www.oschina.net/code/snippet_153403_9880
[xPlugins] jQuery Contextmenu右键菜单的更多相关文章
- 3种不同的ContextMenu右键菜单演示
简单使用的右键菜单,希望能帮助大家.下面是截图和实例代码 实例预览 <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional/ ...
- vue2.0的contextmenu右键菜单
1.事情对象 <!DOCTYPE html> <html> <head> <title></title> <meta charset= ...
- WPF中ContextMenu(右键菜单)使用Command在部分控件上默认为灰色的处理方法
原文:WPF中ContextMenu(右键菜单)使用Command在部分控件上默认为灰色的处理方法 问题描述 今天发现如果我想在一个TextBlock弄一个右键菜单,并且使用Command绑定,结果发 ...
- JQuery之ContextMenu(右键菜单)
插件下载地址:http://www.trendskitchens.co.nz/jquery/contextmenu/jquery.contextmenu.r2.js压缩版:http://www.tre ...
- jquery实现右键菜单
<!DOCTYPE html> <head> <meta http-equiv="Content-Type" content="text/h ...
- jQuery EasyUI 右键菜单--关闭标签/选项卡
目录结构: noContextMenu.js 文件内容如下: $(function(){ //屏蔽右键菜单 $(document).bind("contextmenu", func ...
- 用jQuery修改右键菜单
概述 以前在网上找过屏蔽右键菜单的代码,也找过屏蔽F12的代码,今天无意之中看到别人的右键菜单很有意思,我也想来搞一个. 思路 建立一个菜单并且隐藏起来. 用window.oncontextmenu屏 ...
- jquery 自定义右键菜单
如果要自定义右键菜单,那么就需要禁止原本的右键菜单,代码如下 document.oncontextmenu = new Function("return false;");//禁止 ...
- 实现JQuery EasyUI右键菜单变灰不可用效果
使用过EasyUI的朋友想必都知道疯狂秀才写的后台界面吧,作为一个初学者我不敢妄自评论它的好坏,不过它确实给我们提供了一个很好框架,只要在它的基础上进行修改,基本上都可以满足我们开发的需要. 知道“疯 ...
随机推荐
- 《Java编程思想》学习笔记(一)
1——面向对象和JVM基础 1.java中的4种访问制权限: (1).public:最大访问控制权限,对所有的类都可见. (2).protect:同一包可见,不在同一个包的所有子类也可见. (3). ...
- 我的C++笔记(数据的共享与保护)
*数据的共享与保护: * .作用域: * 作用域是一个标识符在程序正文中有效的区域.C++中标识符的作用域有函数原型作用域.局部作用域(块作用域).类作用域和命名空间作用域. * ().函数原型作用域 ...
- javascript 基础知识点
NaN; // NaN表示Not a Number,当无法计算结果时用NaN表示 Infinity; // Infinity表示无限大,当数值超过了JavaScript的Number所能表示的最大值时 ...
- (转)淘淘商城系列——Solr集群搭建
http://blog.csdn.net/yerenyuan_pku/article/details/72957201 我们之前做的搜索使用的是Solr的单机版来实现的,正是由于我们现在商品数据量不多 ...
- Redis 通用key操作命令
1.在redis里面允许模糊查询key,有3个通配符:*,?,[]. *:通配任意字符 ?:通配单个字符 []:通配中括号内的某个字符 例如: 2.randomKey 随机返回所有key中的某个 3. ...
- python tips:类的专有属性
实例通常能够调用类的属性,但是有些属性是类专有的,实例无法调用. 实例调用方法时查找属性时,首先在自己的__dict__中找,找不到去类中找,在类中能够找到的属性都位于dir(cls)中,如果类的某些 ...
- day008 字符编码之 字符编码 、Python2和Python3字符编码的区别
计算机基础(掌握) 启动应用程序的流程 双击qq 操作系统接受指令然后把该操作转化为0和1发送给CPU CPU接受指令然后把指令发送给内存 内存接受指令把指令发送给硬盘获取数据 qq在内存中运行 文本 ...
- PAT_A1125#Chain the Ropes
Source: PAT A1125 Chain the Ropes (25 分) Description: Given some segments of rope, you are supposed ...
- CSS max-width: 0;
写CSS,大家都知道max-width是要在宽度超过后才会生效,但今天我发现一个神奇的现象, 为表格td加上max-width: 0;可以让上下两个表格自动对齐,这句的作用到底是什么还有待研究,今天先 ...
- Python中字符串操作函数string.split('str1')和string.join(ls)
Python中的字符串操作函数split 和 join能够实现字符串和列表之间的简单转换, 使用 .split()可以将字符串中特定部分以多个字符的形式,存储成列表 def split(self, * ...