vuejs怎么遞歸樹型菜單組件

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

目前創(chuàng)新互聯(lián)建站已為上1000+的企業(yè)提供了網(wǎng)站建設(shè)、域名、雅安服務(wù)器托管、網(wǎng)站托管、服務(wù)器租用、企業(yè)網(wǎng)站設(shè)計(jì)、奉新網(wǎng)站維護(hù)等服務(wù),公司將堅(jiān)持客戶導(dǎo)向、應(yīng)用為本的策略,正道將秉承"和諧、參與、激情"的文化,與客戶和合作伙伴齊心協(xié)力一起成長(zhǎng),共同發(fā)展。

Vue的優(yōu)點(diǎn)

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

遞歸組件

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

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

[
  {
   "id": "1",
   "menuName": "基礎(chǔ)管理",
   "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": "權(quán)限管理",
     "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,無(wú)限ul套li,標(biāo)題用div元素包裹,

<template>
 <li>
  <span @click="toggle">   <!-- toggle:點(diǎn)擊關(guān)閉展開 -->
   <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>

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

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

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

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

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

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

利用vue計(jì)算屬性動(dòng)態(tài)改變isFolder的值,修改圖標(biāo),判斷存在不子級(jí)和子級(jí)長(zhǎng)度

  computed: {
   isFolder() { //利用vue計(jì)算屬性動(dòng)態(tài)改變isFolder的值,修改圖標(biāo),判斷存在不子級(jí)和子級(jí)長(zhǎng)度
    // 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
    }
   }
  },

感謝你能夠認(rèn)真閱讀完這篇文章,希望小編分享的“vuejs怎么遞歸樹型菜單組件”這篇文章對(duì)大家有幫助,同時(shí)也希望大家多多支持創(chuàng)新互聯(lián),關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道,更多相關(guān)知識(shí)等著你來(lái)學(xué)習(xí)!

分享名稱:vuejs怎么遞歸樹型菜單組件
URL地址:http://bm7419.com/article2/geihic.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供品牌網(wǎng)站建設(shè)、關(guān)鍵詞優(yōu)化網(wǎng)頁(yè)設(shè)計(jì)公司、網(wǎng)站設(shè)計(jì)、外貿(mào)建站面包屑導(dǎo)航

廣告

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

成都網(wǎng)頁(yè)設(shè)計(jì)公司