上代码:
<%@ page language="java" contentType="text/html; charset=UTF-8" pageEncoding="UTF-8"%>
<%@ include file="/common/include.jspf"%>
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=UTF-8" />
<script type="text/javascript" src='js/jquery.outlook.js'></script>
<script type="text/javascript">
$(function(){
$.ajax({
data:{
"id":'0'
},
url: Liyong.base+'/system/menu/initInfoMenu.so',
type:'post',
dataType:"json",
success:function(data){
if(data.success) {
if (data.json)
$(data.json).each(function (index, data) {
$('#west_accordion').accordion('add',{
title:data.text,
iconCls:'icon-menu',
content:'<div style="overflow:auto;width:100%;height:100%;">'+
'<ul id="'+data.id+'" class="jquery-tree"></ul>'+
'</div>'
});
$('#'+data.id).tree("loadData",data.children).tree({
onClick:function(node){
if (node.attributes.url)
addTab(Liyong.base+node.attributes.url, node.text);
}
});
});
} else {
$.messager.show({
icon:'error',
msg:data.err,
title:'错误信息'
});
}
}
});
function addTab(url,tabTitle){
if(!$('#center_panel').tabs('exists', tabTitle)) {
$('#center_panel').tabs('add',{
title:tabTitle,
content:createFrame(url),
iconCls:'icon-save',
closable:true
});
tabClose();
}else{
$('#center_panel').tabs('select', tabTitle);
}
};
function createFrame(url) {
var s = '<iframe scrolling="auto" frameborder="0" src="' + url + '" style="width:100%;height:100%;"></iframe>';
return s;
};
function tabClose()
{
/*双击关闭TAB选项卡*/
$(".tabs-inner").dblclick(function(){
var subtitle = $(this).children("span").text();
$('#tabs').tabs('close',subtitle);
});
$(".tabs-inner").bind('contextmenu',function(e){
$('#mm').menu('show', {
left: e.pageX,
top: e.pageY
});
var subtitle =$(this).children("span").text();
$('#mm').data("currtab",subtitle);
return false;
});
}
//绑定右键菜单事件
//关闭当前
$('#mm-tabclose').click(function(){
var currtab_title = $('#mm').data("currtab");
$('#center_panel').tabs('close',currtab_title);
});
//全部关闭
$('#mm-tabcloseall').click(function(){
$('.tabs-inner span').each(function(i,n){
var t = $(n).text();
$('#center_panel').tabs('close',t);
});
});
//关闭除当前之外的TAB
$('#mm-tabcloseother').click(function(){
var currtab_title = $('#mm').data("currtab");
$('.tabs-inner span').each(function(i,n){
var t = $(n).text();
if(t!=currtab_title)
$('#center_panel').tabs('close',t);
});
});
//关闭当前右侧的TAB
$('#mm-tabcloseright').click(function(){
var nextall = $('.tabs-selected').nextAll();
if(nextall.length==0){
//msgShow('系统提示','后边没有啦~~','error');
alert('后边没有啦~~');
return false;
}
nextall.each(function(i,n){
var t=$('a:eq(0) span',$(n)).text();
$('#center_panel').tabs('close',t);
});
return false;
});
//关闭当前左侧的TAB
$('#mm-tabcloseleft').click(function(){
var prevall = $('.tabs-selected').prevAll();
if(prevall.length==0){
alert('到头了,前边没有啦~~');
return false;
}
prevall.each(function(i,n){
var t=$('a:eq(0) span',$(n)).text();
$('#center_panel').tabs('close',t);
});
return false;
});
//退出
$("#mm-exit").click(function(){
$('#mm').menu('hide');
});
});
</script>
</head>
<body class="jquery-layout">
<noscript><div style=" position:absolute; z-index:100000; height:2046px;top:0px;left:0px; width:100%; background:white; text-align:center;">
<img src='<c:url value="/common/themes/icons/noscript.gif" />' />
</div></noscript>
<div region="north" style="height:60px;padding:10px;">north region</div>
<div region="west" title="<img src='<c:url value="/common/themes/icons/tree.gif" />' style='vertical-align:text-bottom;'>${session.bus_name}导航菜单" split="true" style="width:250px;">
<div id="west_accordion" class="jquery-accordion" fit="true" border="false"></div>
</div>
<div region="center">
<div id="center_panel" class="jquery-tabs" fit="true" border="false">
<!-- 显示内容页面 -->
</div>
</div>
<div id="mm" class="jquery-menu" style="width:150px;">
<div id="mm-tabclose">关闭</div>
<div id="mm-tabcloseall">全部关闭</div>
<div id="mm-tabcloseother">除此之外全部关闭</div>
<div class="menu-sep"></div>
<div id="mm-tabcloseright">当前页右侧全部关闭</div>
<div id="mm-tabcloseleft">当前页左侧全部关闭</div>
<div class="menu-sep"></div>
<div id="mm-exit">退出</div>
</div>
</body>
</html>
- 大小: 158.1 KB
- 大小: 141.5 KB
分享到:
相关推荐
总的来说,这个项目结合了多种技术,利用Struts2处理请求,Spring进行依赖管理和事务控制,Hibernate处理数据,Freemarker生成动态页面,jQuery提供前端交互,而jquery-treeview则提供了树形菜单的可视化。...
在本文中,我们将深入探讨如何使用jQuery来创建和操作树形菜单,以及如何利用特定的jQuery插件——jQuery Light Treeview。树形菜单在网页设计中广泛应用,它们为用户提供了一种有组织的方式来浏览和导航层次结构的...
接下来,通过JavaScript设置zTree的相关参数,如节点数据、显示样式、事件监听等,并调用zTree的初始化方法,将普通列表转化为交互式的树形菜单。 以下是一段简单的zTree初始化代码示例: ```html <!DOCTYPE html>...
在IT行业中,jQuery是一款广泛使用...开发者可以研究项目源码,学习如何在MVC环境中集成jQuery,以及如何处理动态加载的数据来构建响应式的树形菜单。同时,这也涉及到前端与后端的交互,以及数据库的查询和数据建模。
5. **响应式设计**:对于移动设备,可能需要调整树形菜单的布局和交互方式,例如,使用汉堡菜单图标代替展开/折叠箭头,或者在触摸设备上使用滑动手势。 以上就是使用jQuery实现树形菜单的基本方法。通过扩展和定制...
下面我们将深入探讨如何使用jQuery创建树形菜单,以及涉及的关键技术和步骤。 首先,要创建树形菜单,我们需要HTML结构来定义菜单项的层次。通常,我们可以使用`<ul>`和`<li>`标签来表示层级关系,例如: ```html ...
3. **初始化树形菜单**:在JavaScript中,调用`$.fn.zTree.init()`方法,传入DOM元素、配置对象和数据源。 ```javascript var setting = {}; var zNodes = []; // 你的JSON数据 $(function() { $.fn.zTree.init...
然后,使用jQuery的选择器找到菜单容器,调用插件方法初始化树形菜单。 事件处理是实现菜单展开和折叠的关键。在`data.js`中定义的节点上,jQuery会监听用户的点击行为。当用户点击一个节点时,插件会检查该节点...
树形菜单是一种层次化的展示方式,常用于文件管理器、网站导航和复杂的应用程序中,让用户能够快速地浏览和访问多级分类的内容。在邮箱应用中,这种菜单通常用于组织邮件,如收件箱、发件箱、草稿箱以及各个子文件夹...
它可能涵盖了如何引入jQuery库,如何初始化树形菜单,以及如何利用提供的API进行添加、编辑和删除操作。此外,可能还详细解释了如何自定义样式和事件处理程序,以适应不同的设计需求。 另一方面,"jiaoben5412.js...
"js"可能包含的是具体的JavaScript代码,包括初始化树形菜单、处理Ajax请求以及解析和渲染JSON数据的逻辑。通常,这个JavaScript文件会定义一些函数来处理树形菜单的交互,如点击事件,以及与服务器进行Ajax通信的...
"基于jQuery的超强树形菜单"是一个专门用于构建这种交互式树状菜单的库,它提供了丰富的功能和定制选项,使得在网页上创建具有复选框、级联效果以及图片展示的树形菜单变得轻而易举。 jQuery是一个广泛使用的...
"jquery树形菜单"是一个利用jQuery实现的交互式树形菜单组件,它提供了可折叠和收缩的功能,使得网页中的导航更加直观和用户友好。 树形菜单通常用于展示层级结构的数据,比如网站目录、文件系统或组织结构。通过...
本文将详细讲解如何利用jQuery实现拖拽功能,并将其应用于树形菜单,帮助你创建交互性强、用户体验良好的Web应用。 一、jQuery基础 jQuery的核心理念是“Write Less, Do More”,通过封装JavaScript的常用功能,使...
3. **初始化菜单**:在JavaScript中,通过调用`.treeview()`方法对元素进行初始化,设置相关参数,如动画效果、展开/折叠图标等。 ```javascript $(document).ready(function() { $("#menu").treeview({ animated...
**jQuery 实现XML树形菜单**\n\n在网页开发中,树形菜单是一种常见的交互元素,用于组织和展示层次化的信息。jQuery 是一个广泛使用的JavaScript库,它提供了丰富的API来简化DOM操作,使得实现这样的功能变得更加...
1. **初始化树形结构**:首先,需要将数据转换为适合展示的HTML结构。这通常涉及递归函数,将每个父节点和子节点转化为`<ul>`和`<li>`元素,同时保持它们的嵌套关系。 2. **添加搜索框**:在页面上添加一个输入框,...
5. 初始化状态:根据数据初始化菜单的展开/折叠状态,可能需要在页面加载后执行一些jQuery代码。 6. 动态响应:确保菜单在窗口大小变化或屏幕分辨率改变时仍能保持良好的响应性,这可能涉及到媒体查询和自适应布局...
这个插件可能提供了如`$.fn.tree`这样的扩展方法,用于初始化和操作树形菜单。例如: ```html <script src="https://code.jquery.com/jquery-3.x.min.js"></script> <script src="path/to/SimpleTree1.3.js"></...