`
y806839048
  • 浏览: 1129486 次
  • 性别: Icon_minigender_1
  • 来自: 上海
文章分类
社区版块
存档分类
最新评论

ui树形组建的渲染 tag菜单初始化展现控制 (树形)

阅读更多
//将数据表中的数据显示成树形结构
select * from t_b_area t start with t.source_type = 1 connect by t.parent_id = prior t.id。



//树形结构的实体,用到内部类
/**
*
*/
package com.ces.zwww.entity;

import java.util.ArrayList;
import java.util.List;

import javax.persistence.Column;
import javax.persistence.Entity;
import javax.persistence.Table;

import com.ces.xarch.core.entity.LongIDEntity;

@Entity
@Table(name = "T_B_AREA")
public class Area extends LongIDEntity {

/** serialVersionUID(long):. */
private static final long serialVersionUID = -5967350210592855795L;

private String name;
private String mask;
private String remark;
private String address;

@Column(name="business_ip")
private String businessIp;

@Column(name="source_type")
private String sourceType;

@Column(name="parent_name")
private String parentName;

@Column(name="parent_id")
private Long parentId;

@Column(name="start_ip")
private String startIp;

@Column(name="end_ip")
private String endIp;

public String getName() {
return name;
}

public void setName(String name) {
this.name = name;
}

public String getMask() {
return mask;
}

public void setMask(String mask) {
this.mask = mask;
}

public String getRemark() {
return remark;
}

public void setRemark(String remark) {
this.remark = remark;
}

public String getAddress() {
return address;
}

public void setAddress(String address) {
this.address = address;
}

public String getBusinessIp() {
return businessIp;
}

public void setBusinessIp(String businessIp) {
this.businessIp = businessIp;
}

public String getSourceType() {
return sourceType;
}

public void setSourceType(String sourceType) {
this.sourceType = sourceType;
}

public String getParentName() {
return parentName;
}

public void setParentName(String parentName) {
this.parentName = parentName;
}

public Long getParentId() {
return parentId;
}

public void setParentId(Long parentId) {
this.parentId = parentId;
}

public String getStartIp() {
return startIp;
}

public void setStartIp(String startIp) {
this.startIp = startIp;
}

public String getEndIp() {
return endIp;
}

public void setEndIp(String endIp) {
this.endIp = endIp;
}

public class Tree {
private Long id;
private String name;
private String type;
private String mask;
private String busip;
private List<Tree> children;

public Tree(){

}

public Tree(Long id, String name, String type, String mask, String busip){
this.id = id;
this.name = name;
this.type = type;
this.mask = mask;
this.busip = busip;
this.children = new ArrayList<Area.Tree>();
}

public Long getId() {
return id;
}

public void setId(Long id) {
this.id = id;
}

public String getName() {
return name;
}

public void setName(String name) {
this.name = name;
}

public String getType() {
return type;
}

public void setType(String type) {
this.type = type;
}

public String getMask() {
return mask;
}

public void setMask(String mask) {
this.mask = mask;
}

public String getBusip() {
return busip;
}

public void setBusip(String busip) {
this.busip = busip;
}

public List<Area.Tree> getChildren() {
return children;
}

public void setChildren(List<Area.Tree> children) {
this.children = children;
}

public void addChildren(Area.Tree tree) {
children.add(tree);
}
}
}





public List<Area.Tree> findByTree(){
List<Area.Tree> trees = new ArrayList<Area.Tree>();
List<Area> results = getDao().findByTree();
for (Area area : results) {
Area.Tree node = null;
if("1".equals(area.getSourceType())){
node = area.new Tree(area.getId(), area.getName(), area.getSourceType(), area.getMask(), area.getBusinessIp());
trees.add(node);
}else if("2".equals(area.getSourceType())){
node = getTreeNode(trees);
node.addChildren(area.new Tree(area.getId(), area.getName(), area.getSourceType(), area.getMask(), area.getBusinessIp()));
}else if("3".equals(area.getSourceType())){
node = getTreeNode(getTreeNode(trees).getChildren());
node.addChildren(area.new Tree(area.getId(), area.getName(), area.getSourceType(), area.getMask(), area.getBusinessIp()));
}
}
return trees;
}



<%
String data = IOUtil.ajaxContent(pageContext.getAttribute("basePath")+"/area!tree.json?parentId=0");
pageContext.setAttribute("ajaxdata", data);
%>

<!-- 左侧导航栏 -->
<uitag-core:sidebar collapse="false">
<uitag-core-sidebar:navitems>
<uitag-core-sidebar:navitem icon="fa-desktop" dropdown="true" title="资源分类" current="open" root="true">
<system:auth resKey="zwww.zygl.wlsb">
<uitag-core-sidebar:navitem icon="fa-caret-right" dropdown="true" tree="true" title="网络设备" url="wlsb/list.jsp" onclick="onSidebarClick(this)">
<cui:tree id="tree1" data="treedata" onClick="onTreeNodeClick"></cui:tree>
</uitag-core-sidebar:navitem>
</system:auth>
<system:auth resKey="zwww.zygl.aqsb">
<uitag-core-sidebar:navitem icon="fa-caret-right" dropdown="true" tree="true" title="安全设备" url="aqsb/list.jsp" onclick="onSidebarClick(this)">
<cui:tree id="tree2" data="treedata" onClick="onTreeNodeClick"></cui:tree>
</uitag-core-sidebar:navitem>
</system:auth>
<system:auth resKey="zwww.zygl.fwcc">
<uitag-core-sidebar:navitem icon="fa-caret-right" dropdown="true" tree="true" title="服务器及存储" url="fwqjcc/list.jsp" onclick="onSidebarClick(this)">
<cui:tree id="tree3" data="treedata" onClick="onTreeNodeClick"></cui:tree>
</uitag-core-sidebar:navitem>
</system:auth>
<system:auth resKey="zwww.zygl.jfjg">
<uitag-core-sidebar:navitem icon="fa-caret-right" dropdown="true" tree="true" title="机房机柜" url="jfjg/list.jsp" onclick="onSidebarClick(this)">
<cui:tree id="tree4" data="treedata" onClick="onTreeNodeClick"></cui:tree>
</uitag-core-sidebar:navitem>
</system:auth>
<system:auth resKey="zwww.zygl.gxll">
<uitag-core-sidebar:navitem icon="fa-caret-right" dropdown="true" tree="true" title="光纤链路" url="gxll/list.jsp" onclick="onSidebarClick(this)">
<cui:tree id="tree5" data="treedata" onClick="onTreeNodeClick"></cui:tree>
</uitag-core-sidebar:navitem>
</system:auth>
<system:auth resKey="zwww.zygl.yhjd">
<uitag-core-sidebar:navitem icon="fa-caret-right" dropdown="true" tree="true" title="用户节点" url="yhjd/list.jsp" onclick="onSidebarClick(this)">
<cui:tree id="tree6" data="treedata" onClick="onTreeNodeClick"></cui:tree>
</uitag-core-sidebar:navitem>
</system:auth>
<system:auth resKey="zwww.zygl.gcs">
<uitag-core-sidebar:navitem icon="fa-caret-right" dropdown="true" tree="true" title="工程师" url="gcs/list.jsp" onclick="onSidebarClick(this)">
<cui:tree id="tree7" data="treedata" onClick="onTreeNodeClick"></cui:tree>
</uitag-core-sidebar:navitem>
</system:auth>
</uitag-core-sidebar:navitem>
</uitag-core-sidebar:navitems>
</uitag-core:sidebar>

//传给url值之后进一步加入参数信息,让iframe加载url+parram
function onTreeNodeClick(event,treeid,node,flag){
var param = "?param=";
switch(node.type){
case "1":param += "{Q_EQ_area:'"+node.name+"'}";break;
case "2":param += "{Q_EQ_center:'"+node.name+"'}";break;
case "3":param += "{Q_EQ_street:'"+node.name+"'}";break;
default:param += "${param.param}";break;
}
$("#ListFrame").attr("src",url+param);
}11111111111111111111111111
//<system:auth resKey="zwww.zygl.yhjd">
//<uitag-core-sidebar:navitem
//icon="fa-caret-right"dropdown="true" tree="true"
//title="用户节点" url="yhjd/list.jsp"
//onclick="onSidebarClick(this)">
//<cui:tree //id="tree6"data="treedata" //onClick="onTreeNodeClick">//</cui:tree></uitag-core-//sidebar:navitem>
//</system:auth>

function onSidebarClick($this){//点击时将此菜单的url赋值
type = $this.title;
url = $($this).attr("url");
}

<script type="text/javascript">
var url,rowdata = {};
var type = '${param.type}';//来自于layout一级大菜单
var area = '${param.area}';
var treedata = [{'id':'0','name':'全市','open':true,'children':eval('(${ajaxdata})')}];
</script>
//来自于layout一级大菜单,点击之后进入这个大类小的页面菜单
<!-- // modify by chanlong on 2014-12-01 09:56 -->
<layout:panel floats="left" width="auto">
<a href="${ctx}/views/zwww/zygl/index.jsp?type=网络设备&area=全市" class="navs-link"><span class="menus menu02">&nbsp;</span></a>
</layout:panel>



//要跳转后的页面
<script type="text/javascript">
var postData = {'Q_EQ_devcType':'wlsb'};
if("${param.param}"){
$.extend(postData, eval("(${param.param})"));//在这里将所有参数组合成json对,以待小项菜单的跳转页面//后的参数使用
}
</script>

//这里由于我们grid的查询,是用postData作为参数的所以这里组装成这样,这样只要重新调用search就上述菜单性的参数全部搞定



function search1() {
var nameip = $('#nameip').val();
var sblx = $('#sblx').combobox( "getValues" ).toString();
var sbzt =  $("#sbzt").radiolist("getValue");
if (nameip != "") {
postData['Q_LIKE_ip'] = nameip;
}
if (sblx != "") {
postData['Q_LIKE_resType'] = sblx;
}

if (sbzt != "all") {
postData['Q_LIKE_status'] = sbzt;
}else{//modify by 包健敏   选择全部的时候需要去掉该查询项
delete postData['Q_LIKE_status'];
}
$('#list1').grid('option', 'postData', postData);
$('#list1').grid('reload');
}



//菜单初始化展现控制

<script type="text/javascript">
$(function(){
clickSidebar();
});

// 根据参数自动触发左侧的树节点的点击事件
function clickSidebar(){
if(type){
$("ul.submenu li a[title='"+type+"']").click();//把当前菜单中属于上级菜中,中符合标题为title的菜单的点击事件激发
//function onSidebarClick($this){//点击时将此菜单的url赋值
// type = $this.title;
// url = $($this).attr("url");
// }

}
if(area){
$("ul.submenu li a[title='"+type+"'] ~ ul.submenu").find("a[title='"+area+"']").click();//先找到匹配的当前的一级菜单,再在此基础上匹配下级菜单中标题符合参数的,激发他的点击事件

//function onTreeNodeClick(event,treeid,node,flag){
//var param = "?param=";
//switch(node.type){
//case "1":param
//+= "{Q_EQ_area:'"+node.name+"'}";break;
//case "2":param += "{Q_EQ_center:'"+node.name+"'}";break;
//case "3":param += "{Q_EQ_street:'"+node.name+"'}";break;
//default:param += "${param.param}";break;
//}
//$("#ListFrame").attr("src",url+param);
//}


//}
//}
</script>
分享到:
评论
发表评论

文章已被作者锁定,不允许评论。

相关推荐

    jsp树形控件

    例如,`&lt;c:forEach&gt;`标签可用于遍历树形结构并渲染节点。不过,JSTL本身并不包含专门用于创建树形控件的标签,所以通常需要结合其他库,如Ajax或JavaScript库(如jQuery UI, Bootstrap Treeview等)来实现交互功能。...

    jsp+mysql+java 写的树形

    在Web开发中,树形结构通常由JavaScript库(如jQuery UI、d3.js或Angular Material)在客户端渲染,但这个项目似乎是在服务器端使用Java处理,然后在JSP页面上显示。这可能涉及到动态生成HTML、Ajax异步请求来加载子...

    Table_表格_Table_matlab_uitable_GUI_

    在MATLAB环境中,数据可视化是科学研究和工程计算中不可或缺的一部分,而`uitable`函数就是用于在图形用户界面(GUI)中创建交互式表格的强大工具。本文将深入探讨`uitable`的功能、属性设置以及如何在MATLAB GUI中...

    JSP语言实现的选择树

    5. 数据文件:可能有JSON格式的预置数据,用于初始化选择树。 6. 文档:详细说明如何部署和使用这些文件。 在实际应用中,JSP语言实现的选择树广泛应用于组织结构展示、文件目录浏览、菜单导航等场景。理解并掌握这...

    JS动态树分组的实现,数据库建表,JSP页面展示

    3. **JSP页面**:设计JSP页面,使用EL和JSTL获取后端传递的数据,初始化JavaScript变量。 4. **JavaScript实现**:编写JavaScript代码,解析JSON数据,构建动态树结构。可能使用了第三方库如jQuery UI的Treeview,或...

    jsp+Java级联菜单

    - 定义`initSel()`函数,用于初始化级联菜单,动态生成主菜单选项。 - `chgSlave()`函数,在主菜单选项改变时触发,用于更新子菜单选项,确保子菜单显示的是与当前主菜单选项相关的数据。 #### 5. HTML与Form元素 ...

    yahoo ui库做的tree控件和简单的CSS表单操作

    3. 初始化Tree控件:在JavaScript中,使用YUI实例化一个TreeView对象,并将数据结构传递给它。 4. 渲染Tree控件:将TreeView对象附加到HTML文档的某个元素上,使树形结构可见。 5. 添加事件监听器:可以为节点添加...

    TaginDemo的3d-tag云优化版

    1. **MainActivity.java**:主程序入口,包含初始化、事件处理等功能。 2. **TagCloudAdapter.java**:适配器类,用于将数据源转化为可视化的标签元素。 3. **TagCloudView.java**:自定义视图类,实现3D标签云的...

    vue+elementUI

    同时,Vue CLI提供的各种脚手架工具能帮助开发者快速初始化项目,设置Webpack配置,以及进行代码打包和优化。 总结来说,"Vue+ElementUI"是一个高效、美观的前端开发组合,结合Node.js和Nginx,可以构建出高效、...

    jQuery回车创建创建标签代码.zip

    2. **初始化已设标签**:如果你已经有了预定义的标签,可以使用jQuery将它们渲染到页面上。这通常涉及到遍历标签数据,为每个标签创建一个`&lt;li&gt;`元素,并将其插入到UI中。 ```javascript var initialTags = ['标签1...

    e语言-易语言标签云特效

    2. **初始化标签**:根据数据加载所有的标签,并设定初始状态,比如随机的大小和颜色。 3. **动画逻辑**:编写动画循环,通过定时器控制每帧的更新。每一帧中,调整标签的位置、大小和颜色,模拟云动的效果。这可能...

    surfaceview 打标签修改版

    3. **实现绘图逻辑**:在SurfaceHolder的 SurfaceCreated() 方法中,我们可以初始化绘图所需的Canvas对象。然后在SurfaceChanged()和SurfaceDestroyed()方法中根据需要调整绘图状态。标签的绘制通常包括设置画笔颜色...

    react-tag-input:React和可编辑标签的简单标签输入组件

    6. **可扩展性**:支持自定义渲染功能,包括标签的呈现方式、输入框的行为等,使得组件可以适应各种复杂的UI需求。 7. **无障碍性**:考虑到了无障碍访问(A11Y),确保组件对于使用辅助技术的用户也是可用的。 8....

    语言技术: JSP/Servlet

    2. **Servlet的生命周期方法**: `init()`用于初始化Servlet,`service()`处理客户端请求,`destroy()`在Servlet不再使用时进行清理工作。此外,`doGet()`和`doPost()`处理HTTP GET和POST请求。 3. **Servlet配置**:...

    myfaces-all-1.1.1.jar

    这些组件涵盖了JSF生命周期的各个阶段,如初始化、渲染、处理用户输入等。例如,它包含Facelets模板引擎,使得开发者可以使用声明式方式构建用户界面,增强了HTML和JSF之间的交互。 在myfaces-all-1.1.1.jar中,你...

    JSF驱动包

    2. 控制层:JSF生命周期管理用户请求,包括初始化、处理事件、更新模型和渲染响应。每个组件都有一个关联的行为,可以处理用户交互。 3. 模型层:JSF与业务逻辑进行交互,通常通过Managed Beans实现。Managed Beans...

    jsf2.0 自定义组件

    6. **组件的生命周期**:JSF组件有自己的生命周期,包括初始化、处理请求、应用请求值、验证、更新模型值和渲染响应等阶段。在这些阶段中,开发者可以在特定的生命周期方法中插入自定义代码。 7. **自定义组件示例*...

    Duilib 实现多标签多网页

    1. **初始化Duilib框架**:首先,你需要初始化Duilib框架,设置消息循环和资源管理器等。 2. **创建主窗口**:定义并创建主窗口,可以设定窗口的基本属性,如大小、位置、样式等。 3. **添加Page控件**:在主窗口...

    Extjs中文教程

    - 组件从创建到销毁的过程称为生命周期,主要包括初始化、渲染、激活、销毁等阶段。 - 了解每个阶段发生的事情有助于更好地控制组件的行为。 - **组件渲染方法render** - `render`方法用于将组件渲染到DOM树中。...

    安卓3D标签云卡片热门相关-AndroidTagGroup实现云标签效果.zip

    3. **实例化并配置AndroidTagGroup**:在布局XML文件中添加AndroidTagGroup视图,并在代码中初始化,设置数据集和各种回调。 4. **处理用户交互**:实现点击、长按等事件监听器,为用户提供反馈和功能。 总的来说,...

Global site tag (gtag.js) - Google Analytics