给jquery easy-ui 添加右键菜单

版权声明:转自为EasyUI 的Tab 标签添加右键菜单



  1 <!doctype html>
  2 <html>
  3 <head>
  4     <meta http-equiv="content-type" content="text/html; charset=UTF-8">
  5     <title>tabs 右键菜单demo QQ:15129679</title>
  6     <link rel="stylesheet" type="text/css" href="static/js/easyui/themes/icon.css" />
  7     <link rel="stylesheet" type="text/css" href="static/js/easyui/themes/default/easyui.css" />
  8     <link rel="stylesheet" type="text/css" href="static/js/zTree/zTreeStyle/zTreeStyle.css" />
  9     <script type="text/javascript" src="static/js/jquery.min.js"></script>
 10     <script type="text/javascript" src="static/js/easyui/jquery.easyui.min.js"></script>
 11     <script type="text/javascript" src="static/js/zTree/jquery.ztree.min.js"></script>
 12 </head>
 13 <body class="easyui-layout">
 14     <div data-options="region:‘north‘,border:false" style="height: 60px; padding: 10px">
 15         tabs 右键菜单demo QQ:15129679</div>
 16     <div data-options="region:‘west‘,split:true,title:‘操作菜单‘" style="width: 150px; padding: 10px;">
 17         <ul id="webMenu_list" class="ztree" style="display: ;">
 18         </ul>
 19     </div>
 20     <div data-options="region:‘center‘,title:‘‘,border:false">
 21         <div id="tt" class="easyui-tabs" data-options="fit:true">
 22             <div title="首页" style="padding: 20px;">
 23                 <h3>
 24                     欢迎您来到网站信息管理系统<br>
 25                     我的博客地址:http://www.cnblogs.com/yeminglong/p/3745914.html
 26
 27                     </h3>
 28             </div>
 29         </div>
 30     </div>
 31     <div id="mm" class="easyui-menu" style="width:120px;">
 32          <div id="mm-tabclose" data-options="name:1">关闭</div>
 33         <div id="mm-tabcloseall" data-options="name:2">全部关闭</div>
 34         <div id="mm-tabcloseother" data-options="name:3">除此之外全部关闭</div>
 35         <div class="menu-sep"></div>
 36         <div id="mm-tabcloseright" data-options="name:4">当前页右侧全部关闭</div>
 37         <div id="mm-tabcloseleft" data-options="name:5">当前页左侧全部关闭</div>
 38
 39     </div>
 40     <script type="text/javascript">
 41
 42
 43         //添加Tabs
 44         function addTabs(event, treeId, treeNode, clickFlag){
 45             if(!$("#tt").tabs(‘exists‘, treeNode.name)){
 46                 $(‘#tt‘).tabs(‘add‘,{
 47                     id:treeId,
 48                     title: treeNode.name,
 49                     selected: true,
 50                     href:treeNode.dataurl,
 51                     closable:true
 52                 });
 53             }else $(‘#tt‘).tabs(‘select‘,treeNode.name);
 54         }
 55
 56         //删除Tabs
 57         function closeTab(menu, type){
 58             var allTabs = $("#tt").tabs(‘tabs‘);
 59             var allTabtitle = [];
 60             $.each(allTabs,function(i,n){
 61                 var opt=$(n).panel(‘options‘);
 62                 if(opt.closable)
 63                     allTabtitle.push(opt.title);
 64             });
 65
 66             switch (type){
 67                 case 1 :
 68                     var curTabTitle = $(menu).data("tabTitle");
 69                     $("#tt").tabs("close", curTabTitle);
 70                     return false;
 71                 break;
 72                 case 2 :
 73                     for(var i=0;i<allTabtitle.length;i++){
 74                         $(‘#tt‘).tabs(‘close‘, allTabtitle[i]);
 75                     }
 76                 break;
 77                 case 3 :
 78
 79                 break;
 80                 case 4 :
 81
 82                 break;
 83                 case 5 :
 84
 85                 break;
 86             }
 87
 88         }
 89
 90
 91         $(document).ready(function () {
 92             //监听右键事件,创建右键菜单
 93             $(‘#tt‘).tabs({
 94                 onContextMenu:function(e, title,index){
 95                     e.preventDefault();
 96                     if(index>0){
 97                         $(‘#mm‘).menu(‘show‘, {
 98                             left: e.pageX,
 99                             top: e.pageY
100                         }).data("tabTitle", title);
101                     }
102                 }
103             });
104             //右键菜单click
105             $("#mm").menu({
106                 onClick : function (item) {
107                     closeTab(this, item.name);
108                 }
109             });
110             //treeNodes
111             var zNodes = [
112                 { id:1, pId:0, name:"操作菜单", open:true,url:"",click:false},
113                 { id: 11, pId: 1, name: "杨凌现代农业科技创业网", dataurl: "02.html", target: "_self" },
114                 { id: 12, pId: 1, name: "杨凌外贸农产品质量溯源公共服务平台", dataurl: "02.html", target: "_self" },
115                 { id: 13, pId: 1, name: "华县农产品标准化生产溯源管理系统华县农产品标准化生产溯源管理系统", dataurl: "02.html", target: "_self" },
116                 { id: 14, pId: 1, name: "杨陵区科技局", dataurl: "02.html", target: "_self" },
117                 { id: 15, pId: 1, name: "杨陵区农民专业合作社联合会", dataurl: "02.html", target: "_self" },
118                 { id: 16, pId: 1, name: "杨凌农产品标准化生产溯源管理系统", dataurl: "02.html", target: "_self" },
119                 { id: 17, pId: 1, name: "站点列表", dataurl: "02.html", target: "_self" },
120                 { id: 18, pId: 1, name: "站点列表", dataurl: "02.html", target: "_self" }
121             ];
122
123             var setting = {
124                 view: {
125                     selectedMulti: false
126                 },
127                 callback: {
128                     onClick: addTabs
129                 }
130             };
131
132             $.fn.zTree.init($("#webMenu_list"), setting,zNodes);
133
134         });
135     </script>
136 </body>
137 </html>

html页面

 1 //删除Tabs
 2         function closeTab(menu, type) {
 3             var allTabs = $("#tt").tabs(‘tabs‘);
 4             var allTabtitle = [];
 5             $.each(allTabs, function (i, n) {
 6                 var opt = $(n).panel(‘options‘);
 7                 if (opt.closable)
 8                     allTabtitle.push(opt.title);
 9             });
10             var curTabTitle = $(menu).data("tabTitle");
11             var curTabIndex = $("#tt").tabs("getTabIndex", $("#tt").tabs("getTab", curTabTitle));
12             switch (type) {
13                 case 1:
14                     $("#tt").tabs("close", curTabIndex);
15                     return false;
16                     break;
17                 case 2:
18                     for (var i = 0; i < allTabtitle.length; i++) {
19                         $(‘#tt‘).tabs(‘close‘, allTabtitle[i]);
20                     }
21                     break;
22                 case 3:
23                     for (var i = 0; i < allTabtitle.length; i++) {
24                         if (curTabTitle != allTabtitle[i])
25                             $(‘#tt‘).tabs(‘close‘, allTabtitle[i]);
26                     }
27                     $(‘#tt‘).tabs(‘select‘, curTabTitle);
28                     break;
29                 case 4:
30                     for (var i = curTabIndex; i < allTabtitle.length; i++) {
31                         $(‘#tt‘).tabs(‘close‘, allTabtitle[i]);
32                     }
33                     $(‘#tt‘).tabs(‘select‘, curTabTitle);
34                     break;
35                 case 5:
36                     for (var i = 0; i < curTabIndex-1; i++) {
37                         $(‘#tt‘).tabs(‘close‘, allTabtitle[i]);
38                     }
39                     $(‘#tt‘).tabs(‘select‘, curTabTitle);
40                     break;
41             }
42
43         }

JS——删除

 1 <div id="mm" class="easyui-menu" style="width: 120px;">
 2         <div id="mm-tabclose" name="6">
 3             刷新</div>
 4         <div id="Div1" name="1">
 5             关闭</div>
 6         <div id="mm-tabcloseall" name="2">
 7             全部关闭</div>
 8         <div id="mm-tabcloseother" name="3">
 9             除此之外全部关闭</div>
10         <div class="menu-sep">
11         </div>
12         <div id="mm-tabcloseright" name="4">
13             当前页右侧全部关闭</div>
14         <div id="mm-tabcloseleft" name="5">
15             当前页左侧全部关闭</div>
16     </div>

JS——刷新

 1 //删除Tabs
 2         function closeTab(menu, type) {
 3             var allTabs = $("#tt").tabs(‘tabs‘);
 4             var allTabtitle = [];
 5             $.each(allTabs, function (i, n) {
 6                 var opt = $(n).panel(‘options‘);
 7                 if (opt.closable)
 8                     allTabtitle.push(opt.title);
 9             });
10             var curTabTitle = $(menu).data("tabTitle");
11             var curTabIndex = $("#tt").tabs("getTabIndex", $("#tt").tabs("getTab", curTabTitle));
12             switch (type) {
13                 case 1://关闭当前
14                     $("#tt").tabs("close", cutTabIndex);
15                     return false;
16                     break;
17                 case 2://全部关闭
18                     for (var i = 0; i < allTabtitle.length; i++) {
19                         $(‘#tt‘).tabs(‘close‘, allTabtitle[i]);
20                     }
21                     break;
22                 case 3://除此之外全部关闭
23                     for (var i = 0; i < allTabtitle.length; i++) {
24                         if (curTabTitle != allTabtitle[i])
25                             $(‘#tt‘).tabs(‘close‘, allTabtitle[i]);
26                     }
27                     $(‘#tt‘).tabs(‘select‘, curTabTitle);
28                     break;
29                 case 4://当前侧面右边
30                     for (var i = curTabIndex; i < allTabtitle.length; i++) {
31                         $(‘#tt‘).tabs(‘close‘, allTabtitle[i]);
32                     }
33                     $(‘#tt‘).tabs(‘select‘, curTabTitle);
34                     break;
35                 case 5: //当前侧面左边
36                     for (var i = 0; i < curTabIndex - 1; i++) {
37                         $(‘#tt‘).tabs(‘close‘, allTabtitle[i]);
38                     }
39                     $(‘#tt‘).tabs(‘select‘, curTabTitle);
40                     break;
41                 case 6: //刷新
42                     var panel = $("#tt").tabs("getTab", curTabTitle).panel("refresh");
43                     break;
44             }
45
46         }

js

时间: 2024-10-13 15:56:15

给jquery easy-ui 添加右键菜单的相关文章

JQUERY EASY UI +TREE +SERVLET 显示菜单的例子

1.准备工作 (1)jquery easy ui (2)mysql数据 (3)eclipse开发环境等等 2.开发前端 <body class="easyui-layout"> <div data-options="region:'north',title:'header',split:true,noheader:true" style="height:60px;background:#666;"><div clas

JQuery Easy Ui (Tree树)详解

在这里沉重悼念我辛辛苦苦写了4个小时的文章,因为我的失误,没保存,而夭折啦..... 我的痛苦谁能懂? 哎~~~~  吃一见长一智吧! 么的办法啊! 但是,但是!我狠了狠心,咬了咬牙!我决定,再写一遍!!! 谁知道哭的表情怎么写! 我已经无法用言语表达我此时此刻的沉重心情了! (以下内容,身为菜鸟的我是用颤抖的双手敲出来的,忘同志们珍惜!!!!) 记得4个小时之前,我写过一个随笔,它的内容是这样的: 每次写博客,都喜欢在前面和大家分享一些东西,今天要分享的是一个小故事: 一个世界著名的大酒店正在

JQuery Easy Ui (Tree树)详解(转)

JQuery Easy Ui (Tree树)详解(转) 第一讲:JQuery Easy Ui到底是什么呢? 首先咱们知道JQuery是对Java Script的封装,是一个js库,主要提供的功能是选择器,属性修改和事件绑定等等.. JQuery ui是在jQuery的基础上,利用jQuery的扩展性,设计的插件. 那么JQuery Easy Ui到底是什么呢? 我的理解就是比JQuery ui更强大,同样都是实现绚丽的多功能效果! jQuery Easy UI的目的就是帮助Web开发者更轻松的打

jQuery Easy UI Panel(面板)组件

panel(面板)组件,跟前面的组件用法几乎都差不多,也是从设置一些面板属性.操作面板触发的事件.我们可针对面板对象的操作方法这三个点去学习. 后面有一些组件要依赖于这个组件. 还有一点跟前面不同的就是面板内容可以请求远程数据. 示例: <!DOCTYPE html> <html> <head> <title>jQuery Easy UI</title> <meta charset="UTF-8" /> <s

jquery easy ui 1.5最新版本 简单的权限分配

jquery easy 1.5 Maven+servlet+jsp+jdbc实现权限管理分配 首先,我先说明下,我只是一个菜鸟,我只是在编程道路上摸索的一个的小码农.做开发三年了,这好像是我第一次写博客.以前接触过类似于jquery easy  ui 的DWZ,是我第一家公司用的UI框架.所以用easy ui感觉很快能上手.都是基于jquery 的ui框架.好,废话少说.此次项目我是用最基础的jsp+servlet+jdbc写的,同时加入了maven管理jar包以及发布.应该很好理解的. 1.准

Jquery Easy UI初步学习(二)datagrid的使用

第一篇学的是做一个管理的外框,接着就是数据datagrid绑定了,这里我用asp.net mvc3来做的,主要就是熟悉属性.方法. 打开easyui的demo 就可以看到如下一段代码: 和上篇一样class="easyui-datagrid", data-options="...",这是一样的,其他我在网上查了查,并做了整理 DataGrid 属性 参数名 类型 描述 默认值 title string Datagrid面板的标题 null iconCls strin

jQuery Easy UI (适应屏幕分辨率大小)布局(Layout)

一.jQuery Easy UI (适应屏幕分辨率大小)布局(Layout) 1.首先应用的是jquery-easyui-1.4 版本(版本不同,兼容性不同) 2.实现整个页面的布局( layout: north,south,west,east, center) 3.首先整个页面布局适应屏幕的分辨率大小 4.然后内容区域进行布局,也要适应屏幕分辨率大小 5.部分代码: 1 <body> 2 <div class="easyui-layout" fit="tr

jQuery Easy UI整理笔记目录

jQuery Easy UI整理笔记目录 ps:最近对Easy UI比较感兴趣,打算系统的学习一下,前面基础部分的东西很简单,都是参照API去写的,例子也就是随便举的,没有列举项目中的实际应用. 打算基础部分后面的知识多投入点时间,多与项目中的实际相结合一些,也尽量多想象出一些应用场景. 计划最慢每周更新一篇文章. 一.基础组件部分 1. jQuery Easy UI的使用 2. jQuery Easy UI Draggable(拖动)组件 3. jQuery Easy UI Droppable

7个jquery easy ui 基本组件图解

以下给出7个jquery easy ui 基本组件: 1 基本面板 <!DOCTYPE html> <html> <head> <meta charset="UTF-8"> <title>Basic Panel - jQuery EasyUI Demo</title> <link rel="stylesheet" type="text/css" href=".