成人午夜视频全免费观看高清-秋霞福利视频一区二区三区-国产精品久久久久电影小说-亚洲不卡区三一区三区一区

vue+java實現(xiàn)多級菜單遞歸效果

效果如圖:

堅守“ 做人真誠 · 做事靠譜 · 口碑至上 · 高效敬業(yè) ”的價值觀,專業(yè)網(wǎng)站建設服務10余年為成都成都建筑動畫小微創(chuàng)業(yè)公司專業(yè)提供企業(yè)網(wǎng)站建設營銷網(wǎng)站建設商城網(wǎng)站建設手機網(wǎng)站建設小程序網(wǎng)站建設網(wǎng)站改版,從內(nèi)容策劃、視覺設計、底層架構(gòu)、網(wǎng)頁布局、功能開發(fā)迭代于一體的高端網(wǎng)站建設服務。

vue+ java 實現(xiàn)多級菜單遞歸效果

大概思路:樹形視圖使用的是vue官方事例代碼,java負責封裝數(shù)據(jù),按照vue官方事例的數(shù)據(jù)結(jié)構(gòu)封裝數(shù)據(jù)即可。有兩個需要關(guān)注的點:

1.官方事例的數(shù)據(jù)結(jié)構(gòu)是一個對象里面包含著集合,而不是一個集合對象 2.遞歸算法

上代碼:

前端:html+js

<html>
 <head>
 <meta charset="UTF-8">
 <title></title>
 <script src="https://cdn.jsdelivr.net/npm/vue@2.6.9/dist/vue.js"></script>
 <!-- 引入樣式 -->
 <link rel="stylesheet"  rel="external nofollow" >
 <!-- 引入組件庫 -->
 <script src="https://unpkg.com/element-ui/lib/index.js"></script>
 <script src="https://unpkg.com/axios/dist/axios.min.js"></script>
 <script src="${ctx}/core-plugins/ew/depend/jquery/jquery.min.js" type="text/javascript"></script>
<style>
 body {
 font-family: Menlo, Consolas, monospace;
 color: #444;
}
.item {
 cursor: pointer;
}
.bold {
 font-weight: bold;
}
ul {
 padding-left: 1em;
 line-height: 1.5em;
 list-style-type: dot;
}
</style>
<script type="text/x-template" id="item-template">
 <li>
 <div :class="{bold: isFolder}" @click="toggle" @dblclick="makeFolder">
  {{ item.name }}
 
  <span v-if="isFolder">[{{ isOpen ? '-' : '+' }}]</span>
 </div>
 <ul v-show="isOpen" v-if="isFolder">
  <tree-item
  class="item"
  v-for="(child, index) in item.children"
  :key="index"
  :item="child"
  @make-folder="$emit('make-folder', $event)"
  @add-item="$emit('add-item', $event)"
  ></tree-item>
  <li class="add" @click="$emit('add-item', item)">+</li>
 </ul>
 </li>
</script>
</head>
<body>
 
 <div id="demo">
 <ul >
 <tree-item class="item" :item="treeData" @make-folder="makeFolder" @add-item="addItem"> </tree-item>
 </ul>
 </div>
</body>
</html>
<script>
 Vue.component('tree-item', {
 template: '#item-template',
 props: {
  item: Object 
 },
 data: function () {
  return {
  isOpen: false
  }
 },
 computed: {
  isFolder: function () {
  return this.item.children &&
   this.item.children.length
  }
 },
 methods: {
  toggle: function () {
  if (this.isFolder) {
   this.isOpen = !this.isOpen
  };
  },
  makeFolder: function () {
  if (!this.isFolder) {
   this.$emit('make-folder', this.item)
   this.isOpen = true
  }
  }
 }
 })
 var demo = new Vue({
 el: '#demo',
 data: {
  treeData: {}
 },
 methods: {
  makeFolder: function (item) {
  Vue.set(item, 'children', [])
  this.addItem(item)
  },
  addItem: function (item) {
  item.children.push({
   name: 'new stuff'
  })
  },
  searchData:function(){
  debugger;
 axios.get('menuRoleLimitBLH_searchMenus.do?pageType=1')
 .then(response => (
  this.treeData = response.data.json.menuMaps
  ))
 .catch(error => console.log(error));
 }
 },
 created() {
 this.searchData();
  },
 
 
 })
</script>

后臺:java +MySQL,一共三個方法,分別是:1.獲取請求 2獲取所有菜單 3遞歸菜單的父子關(guān)系

/**
 * Purpose:菜單列表頁面
 * @author JaxWan
 * @param req
 * @return IZrarResponse
 */
 public IZrarResponse searchMenus(IZrarRequest req){
 IZrarResponse res = new ZrarResponse();
 String pageType = req.getParameter("pageType");
 if(StringUtil.isNotNull(pageType)){
 List<EwTreeVO> EwTreeVOs = dao.selectList("selectAllMenuTree");
 List<Map<String, Object>> menus = this.getMenusList(EwTreeVOs);
 Map<String, Object> map = new HashMap<String, Object>();
 map.put("id", 1);
 map.put("name", 2);
 map.put("children", menus);
 res.addJson("menuMaps", map);
 }else {
 res.addPage("pages/ewsys/dept/menu_role_limit.jsp").addJSTL("isExtForm", false).addJSTL("isEmptyForm", false);
 }
 return res;
 }
/**
 * Purpose:獲取菜單集合
 * @author JaxWan
 * @param EwTreeVOs
 * @return List<Map<String,Object>>
 */
 public List<Map<String, Object>> getMenusList(List<EwTreeVO> EwTreeVOs){
 List<Map<String, Object>> menus = new ArrayList<Map<String,Object>>();
 for (int i = 0; i < EwTreeVOs.size(); i++) {
 EwTreeVO ewTreeVO = EwTreeVOs.get(i);
 String id = ewTreeVO.getId();
 String name = ewTreeVO.getName();
 String pId = ewTreeVO.getpId();
 Map<String, Object> map = new HashMap<String, Object>();
 map.put("id", id);
 map.put("name", name);
 map.put("pId", pId);
 Map<String, Object> map2 = this.digui(id, EwTreeVOs,map);
 menus.add(map2);
 }
 return menus;
 }
 
 /**
 * Purpose:遞歸父子關(guān)系
 * @author JaxWan
 * @param id 父節(jié)點id
 * @param EwTreeVOs2 菜單集合
 * @param mapResult 結(jié)果集
 * @param lists 孩子集合
 * @return Map<String,Object>
 */
 public Map<String, Object> digui(String id,List<EwTreeVO> EwTreeVOs2,Map<String, Object> mapResult){
 List<Map<String, Object>> lists = new ArrayList<Map<String,Object>>();
 for (int j = 0; j < EwTreeVOs2.size(); j++) {
 EwTreeVO ewTreeVO2 = EwTreeVOs2.get(j);
 String id2 = ewTreeVO2.getId();
 String name2 = ewTreeVO2.getName();
 String pId2 = ewTreeVO2.getpId();
 if(id.equals(pId2)){
 Map<String, Object> map2 = new HashMap<String, Object>();
 map2.put("id", id2);
 map2.put("name", name2);
 map2.put("pId", pId2);
 lists.add(map2);
 EwTreeVOs2.remove(j);
 j--;
 }
 }
 mapResult.put("children", lists);
 for (int i = 0; i < lists.size(); i++) {
 Map<String , Object> tempMap = lists.get(i);
 String id1 = (String) tempMap.get("id");
 this.digui(id1,EwTreeVOs2,tempMap);
 }
 return mapResult;
 }

總結(jié)

以上所述是小編給大家介紹的vue+ java 實現(xiàn)多級菜單遞歸效果,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復大家的。在此也非常感謝大家對創(chuàng)新互聯(lián)網(wǎng)站的支持!
如果你覺得本文對你有幫助,歡迎轉(zhuǎn)載,煩請注明出處,謝謝!

當前題目:vue+java實現(xiàn)多級菜單遞歸效果
當前路徑:http://jinyejixie.com/article2/jjpsoc.html

成都網(wǎng)站建設公司_創(chuàng)新互聯(lián),為您提供ChatGPT、App開發(fā)、用戶體驗、網(wǎng)站內(nèi)鏈、品牌網(wǎng)站制作、網(wǎng)站建設

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時需注明來源: 創(chuàng)新互聯(lián)

外貿(mào)網(wǎng)站建設
康乐县| 额敏县| 双牌县| 朝阳县| 蓬莱市| 磐安县| 美姑县| 东至县| 曲阳县| 灌阳县| 蚌埠市| 曲靖市| 通辽市| 通江县| 二手房| 雅安市| 拉萨市| 三明市| 荆州市| 炉霍县| 耿马| 平定县| 罗甸县| 巩留县| 澜沧| 呼玛县| 新乡县| 衡阳市| 淄博市| 石渠县| 乐山市| 旺苍县| 重庆市| 南丰县| 林西县| 温宿县| 田东县| 宜阳县| 丹阳市| 册亨县| 太康县|