spring+srpingmvc+hibernate實(shí)現(xiàn)動(dòng)態(tài)ztree生成樹狀圖效果
ztree生成樹狀圖
前臺(tái)
導(dǎo)入js和css包
前端頁面 ztree.jsp
<%@ page contentType="text/html;charset=UTF-8" language="java" pageEncoding="UTF-8" isELIgnored="false" %> <!DOCTYPE html> <HTML> <HEAD> <TITLE>ztree</TITLE> <meta http-equiv="content-type" content="text/html; charset=UTF-8"> <link rel="stylesheet" href="${pageContext.request.contextPath}/Css/demo.css" type="text/css"> <link rel="stylesheet" href="${pageContext.request.contextPath}/Css/zTreeStyle/zTreeStyle.css" type="text/css"> <script type="text/javascript" src="${pageContext.request.contextPath}/Js/jquery-1.4.4.min.js"></script> <script type="text/javascript" src="${pageContext.request.contextPath}/Js/jquery.ztree.core-3.5.js"></script> <SCRIPT type="text/javascript"> //初始化 var setting = { data: { simpleData: { enable: true } }, callback: { beforeClick: beforeClick } }; //數(shù)據(jù)集 var zNodes =[ //根據(jù)這種格式生成樹狀圖 // {id:1, pId:0, name:"河北省"}, // {id:12, pId:1, name:"石家莊"}, // {id:13, pId:1, name:"邢臺(tái)"}, // {id:14, pId:1, name:"邯鄲"}, // {id:2, pId:0, name:"北京市"}, // {id:22, pId:2, name:"海淀區(qū)"}, // {id:23, pId:2, name:"朝陽區(qū)"}, // {id:24, pId:2, name:"長(zhǎng)安區(qū)"} ]; //點(diǎn)擊后的操作 function beforeClick(treeId, treeNode, clickFlag) { //獲取父窗口中id為Text1 var parentControl=parent.document.getElementById("Text1"); //把值設(shè)置為treeNode.name; parentControl.value=treeNode.name; } //訪問控制層,獲取數(shù)據(jù)。 $(document).ready(function(){ var url="${pageContext.request.contextPath}/menu/findZtree"; $.getJSON(url,{},function(nodes){ //alert(nodes); console.log(JSON.stringify(nodes)); zNodes=nodes; $.fn.zTree.init($("#treeDemo"), setting, zNodes); }) }); </SCRIPT> </HEAD> <BODY> <div class="content_wrap"> <div class="zTreeDemoBackground left"> <ul id="treeDemo" class="ztree"></ul> </div> </div> </BODY> </HTML>
后臺(tái)
ztree所需實(shí)體類
package com.shp.dev.common; public class Ztree { private String id; private String pId; private String name; public String getId() { return id; } public void setId(String id) { this.id = id; } public String getpId() { return pId; } public void setpId(String pId) { this.pId = pId; } public String getName() { return name; } public void setName(String name) { this.name = name; } public Ztree() { } public Ztree(String id, String pId, String name) { this.id = id; this.pId = pId; this.name = name; } @Override public String toString() { return "Ztree{" + "id='" + id + '\'' + ", pId='" + pId + '\'' + ", name='" + name + '\'' + '}'; } }
dao接口
package com.shp.dev.menu.dao; import com.shp.dev.menu.pojo.Menu; import java.util.List; public interface MenuDao { List<Menu> queryAll(); }
dao的實(shí)現(xiàn)類
package com.shp.dev.menu.dao; import com.shp.dev.menu.pojo.Menu; import org.hibernate.SessionFactory; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.stereotype.Repository; import java.util.List; @Repository("menuDao") public class MenuDaoImpl implements MenuDao{ @Autowired private SessionFactory sessionFactory; @Override public List<Menu> queryAll() { return sessionFactory.getCurrentSession().createQuery("from Menu").list(); } }
業(yè)務(wù)接口
package com.shp.dev.menu.service; import com.shp.dev.menu.pojo.Menu; import java.util.List; public interface MenuService { List<Menu> queryAll(); }
業(yè)務(wù)實(shí)現(xiàn)層
package com.shp.dev.menu.service; import com.shp.dev.menu.dao.MenuDao; import com.shp.dev.menu.pojo.Menu; import com.shp.dev.role.dao.RoleDao; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.stereotype.Service; import org.springframework.transaction.annotation.Transactional; import java.util.List; @Service("menuService") public class MenuServiceImpl implements MenuService{ //@Transactional(readOnly = true)//只讀事務(wù) // @Transactional(rollbackFor = Exception.class)//啟動(dòng)事務(wù),所有異常都回滾 @Autowired private MenuDao menuDao; @Override @Transactional(readOnly = true)//只讀事務(wù) public List<Menu> queryAll() { return menuDao.queryAll(); } }
控制層
package com.shp.dev.menu.web; import com.shp.dev.common.Ztree; import com.shp.dev.menu.pojo.Menu; import com.shp.dev.menu.service.MenuService; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.stereotype.Controller; import org.springframework.web.bind.annotation.RequestMapping; import org.springframework.web.bind.annotation.ResponseBody; import java.util.ArrayList; import java.util.List; @Controller @RequestMapping("/menu") public class MenuController { @Autowired private MenuService menuService; @RequestMapping("/findZtree") @ResponseBody // 返回json對(duì)象 public List<Ztree> findZtree(){ List<Ztree> menus=new ArrayList<Ztree>(); List<Menu> query = menuService.queryAll(); for (Menu m : query) { menus.add(new Ztree(m.getId(),m.getParent_id(),m.getName())); } return menus; } }
總結(jié)
以上所述是小編給大家介紹的spring+srpingmvc+hibernate實(shí)現(xiàn)動(dòng)態(tài)ztree生成樹狀圖,希望對(duì)大家有所幫助,如果大家有任何疑問請(qǐng)給我留言,小編會(huì)及時(shí)回復(fù)大家的。在此也非常感謝大家對(duì)腳本之家網(wǎng)站的支持!
如果你覺得本文對(duì)你有幫助,歡迎轉(zhuǎn)載,煩請(qǐng)注明出處,謝謝!
相關(guān)文章
IDEA自帶Maven插件找不到settings.xml配置文件
IDEA自帶了Maven插件,最近發(fā)現(xiàn)了一個(gè)問題,IDEA自帶Maven插件找不到settings.xml配置文件,本文就來詳細(xì)的介紹一下解決方法,感興趣的可以了解一下2023-11-11IDEA在一個(gè)工作空間中管理多個(gè)項(xiàng)目的詳細(xì)步驟
這篇文章主要介紹了IDEA在一個(gè)工作空間中管理多個(gè)項(xiàng)目的詳細(xì)步驟,本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2021-01-01關(guān)于Java如何正確地實(shí)現(xiàn)方法重載詳解
在一個(gè)類中,可以定義多個(gè)構(gòu)造方法,這叫做方法的重載!但是關(guān)于方法重載,具有有哪些要求和細(xì)節(jié)?在今天的這篇文章中,小編給大家詳細(xì)說說方法重載相關(guān)的內(nèi)容,需要的朋友可以參考下2023-05-05Java判斷數(shù)字位數(shù)的方法總結(jié)
本文給大家整理了Java判斷數(shù)字位數(shù)的兩種常用方法,對(duì)此有興趣的可以跟著小編一起學(xué)習(xí)下。2018-02-02Java 仿天貓服裝商城系統(tǒng)的實(shí)現(xiàn)流程
讀萬卷書不如行萬里路,只學(xué)書上的理論是遠(yuǎn)遠(yuǎn)不夠的,只有在實(shí)戰(zhàn)中才能獲得能力的提升,本篇文章手把手帶你用java+SSM+jsp+mysql+maven實(shí)現(xiàn)一個(gè)仿天貓服裝商城系統(tǒng),大家可以在過程中查缺補(bǔ)漏,提升水平2021-11-11