溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

vuejs怎么遞歸樹型菜單組件

發(fā)布時間:2021-04-20 13:16:07 來源:億速云 閱讀:223 作者:小新 欄目:web開發(fā)

這篇文章主要介紹了vuejs怎么遞歸樹型菜單組件,具有一定借鑒價值,感興趣的朋友可以參考下,希望大家閱讀完這篇文章之后大有收獲,下面讓小編帶著大家一起了解一下。

Vue的優(yōu)點

Vue具體輕量級框架、簡單易學、雙向數(shù)據(jù)綁定、組件化、數(shù)據(jù)和結(jié)構的分離、虛擬DOM、運行速度快等優(yōu)勢,Vue中頁面使用的是局部刷新,不用每次跳轉(zhuǎn)頁面都要請求所有數(shù)據(jù)和dom,可以大大提升訪問速度和用戶體驗。

遞歸組件

組件在它的模板內(nèi)可以遞歸地調(diào)用自己,只有當它有 name 選項時才可以。 在官網(wǎng)這句話就是關鍵定義組件是一定要有name屬性。

模擬數(shù)據(jù)格式如下:

[
  {
   "id": "1",
   "menuName": "基礎管理",
   "menuCode": "10",
   "children": [
    {
     "menuName": "用戶管理",
     "menuCode": "11"
    },
    {
     "menuName": "角色管理",
     "menuCode": "12",
     "children": [
      {
       "menuName": "管理員",
       "menuCode": "121"
      },
      {
       "menuName": "CEO",
       "menuCode": "122"
      },
      {
       "menuName": "CFO",
       "menuCode": "123"
      },
      {
       "menuName": "COO",
       "menuCode": "124"
      },
      {
       "menuName": "普通人",
       "menuCode": "124"
      }
     ]
    },
    {
     "menuName": "權限管理",
     "menuCode": "13"
    }
   ]
  },
  {
   "id": "2",
   "menuName": "商品管理",
   "menuCode": ""
  },
  {
   "id": "3",
   "menuName": "訂單管理",
   "menuCode": "30",
   "children": [
    {
     "menuName": "訂單列表",
     "menuCode": "31"
    },
    {
     "menuName": "退貨列表",
     "menuCode": "32",
     "children": []
    }
   ]
  },
  {
   "id": "4",
   "menuName": "商家管理",
   "menuCode": "",
   "children": []
  }
 ]

html我們思路按照ul里面套li,無限ul套li,標題用div元素包裹,

<template>
 <li>
  <span @click="toggle">   <!-- toggle:點擊關閉展開 -->
   <i v-if="isFolder" class="icon" :class="[open ? 'folder-open' : 'folder']" @cilck="toggle"></i>
   <!-- <i v-if="isFolder" class="icon " :class="[open ? 'folder-open' : 'folder']"></i> -->
   <i v-if="!isFolder" class="icon folder-text"></i>
   {{model.menuName}}
  </span>
  <ul v-show="open" v-if="isFolder">
   <treeMenu v-for="item in model.children" :model="item"></treeMenu>
  </ul>
 </li>
</template>

官方文檔里面寫的遞歸組件強調(diào)了使用name屬性

需要注意的是,由父組件傳遞過來的數(shù)據(jù)要先進行深拷貝哦

深拷貝:把props賦值到data里,賦值的同時深拷貝一下,data里 JSON.parse(JSON.stringify(這個值就行了)),data值自己命名

export default {
  name: 'treeMenu',
  //props: ['model'], //這樣和下面效果一樣
  props: {
   model: { type: Object },
  },
  components: {},
}

按照vue的思想,不操作Dom樹,我們定義兩個變量,一個顯示隱藏子菜單(open),一個存不存子菜單修改圖標(isFolder)。

  data() {
   return {
    open: false, //一個顯示隱藏子菜單(open)
    //isFolder: true  //這個不要寫死,運用計算屬性計算看存不存在
   }
  },

利用vue計算屬性動態(tài)改變isFolder的值,修改圖標,判斷存在不子級和子級長度

  computed: {
   isFolder() { //利用vue計算屬性動態(tài)改變isFolder的值,修改圖標,判斷存在不子級和子級長度
    // return this.model.children && this.model.children.length //和下面效果一樣
    let isFolder = false
    if (this.model.children && this.model.children.length) {
     isFolder = true;
    } else {
     isFolder = false;
    }
    return isFolder
   }
  },

顯示隱藏事件

  methods: {
   toggle() {
    if (this.isFolder) {
     this.open = !this.open
    }
   }
  },

感謝你能夠認真閱讀完這篇文章,希望小編分享的“vuejs怎么遞歸樹型菜單組件”這篇文章對大家有幫助,同時也希望大家多多支持億速云,關注億速云行業(yè)資訊頻道,更多相關知識等著你來學習!

向AI問一下細節(jié)

免責聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權請聯(lián)系站長郵箱:is@yisu.com進行舉報,并提供相關證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權內(nèi)容。

vue
AI