vue+elementUI使用遞歸實現左側導航欄

一宾舅、首先自己寫一個JSON文件糊识,這個JSON文件就是我們需要的分類的列表。例如:

const menuList = [
  {
    title : '用戶管理',
    key : '/user',
    icon : 'el-icon-user-solid',
  },
  {
    title : '商品',
    key : '/products',
    icon : 'el-icon-s-goods',
    children : [
      {
        title : '品類管理',
        key : '/category',
        icon : 'bars',
      },
      {
        title : '商品管理',
        key : '/product',
        icon : 'tool',
      }
    ]
  },
  {
    title : '用戶管理',
    key : '/userss',
    icon : 'user',
  },
  {
    title : '角色管理',
    key : '/role',
    icon : 'safety'
  },
  {
    title : '圖形圖表',
    key : '/charts',
    icon : 'area-chart',
    children: [
      {
        title : '柱線圖',
        key : '/charts/bar',
        icon : 'bar-chart'
      },
      {
        title : '折線圖',
        key : '/charts/line',
        icon : 'line-chart'
      },
      {
        title : '餅圖',
        key : '/charts/pie',
        icon : 'pie-chart'
      },
    ]
  },
]

export default menuList

二堵未、首先在home組件使用element布局模板腋舌,然后引入我們剛才定義的json文件,并且定義給data中的leftMenus渗蟹,然后創(chuàng)建一個自定義組件home-left块饺,將我們的leftMenus傳給home-left這個子組件

這里要注意:default-active,這個屬性意思是哪一個菜單處于高亮狀態(tài)雌芽,在這里我們可以根據路由來匹配授艰,如果不這樣做,當我們在已經選擇界面刷新的時候膘怕,那么已經選擇的菜單則不會處于高亮狀態(tài)

    <el-container>
      <el-aside>
        <el-menu
          router
          :default-active="$route.path"
          class="el-menu-vertical-demo"
          background-color="#545c64"
          text-color="#fff"
          active-text-color="#ffd04b">
          <home-left :navMenus="leftMenus"/>
        </el-menu>
      </el-aside>
      <el-container>
        <el-main>
          <router-view/>
        </el-main>

<script>
import menuList from '../../util/menuConfig'
export default {
    components: {HomeLeft},
    data() {
      return {
        leftMenus: menuList,
      }
    }
}
</script>

三想诅、在子組件中我們需要使用props來接受傳遞過來的數據,并且在template中把遍歷的children值再傳遞給自己這個組件岛心,遞歸調用自己組件来破。這里的:index是唯一標志,:route是路由路徑

<template>
  <div class="navMenu">
    <label v-for="navMenu in navMenus">
      <!--只有一級菜單-->
      <el-menu-item v-if="!navMenu.children"
                    :index="navMenu.key"
                    :route="navMenu.key"
      >
        <!--圖標-->
        <i :class="navMenu.icon"></i>
        <!--標題-->
        <span slot="title">{{navMenu.title}}</span>
      </el-menu-item>
      <!--有多級菜單-->
      <el-submenu v-if="navMenu.children"
                  :key="navMenu.key"
                  :index="navMenu.key"
      >
        <template slot="title">
          <i :class="navMenu.icon"></i>
          <span> {{navMenu.title}}</span>
        </template>
        <!--遞歸組件忘古,把遍歷的值傳回子組件徘禁,完成遞歸調用-->
        <nav-menu :navMenus="navMenu.children"></nav-menu>
      </el-submenu>
    </label>

  </div>
</template>

<script>
  export default {
    name: 'NavMenu', //使用遞歸組件必須要有
    props: ['navMenus'], // 傳入子組件的數據
    data() {
      return {}
    },
    methods: {
      handleSelect(key,keyPath){
        console.log('1212')
        console.log(key,keyPath)
      }
    }
  }
</script>

<style scoped>

</style>

?著作權歸作者所有,轉載或內容合作請聯系作者
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市髓堪,隨后出現的幾起案子送朱,更是在濱河造成了極大的恐慌娘荡,老刑警劉巖,帶你破解...
    沈念sama閱讀 219,188評論 6 508
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件驶沼,死亡現場離奇詭異炮沐,居然都是意外死亡,警方通過查閱死者的電腦和手機回怜,發(fā)現死者居然都...
    沈念sama閱讀 93,464評論 3 395
  • 文/潘曉璐 我一進店門大年,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人玉雾,你說我怎么就攤上這事翔试。” “怎么了复旬?”我有些...
    開封第一講書人閱讀 165,562評論 0 356
  • 文/不壞的土叔 我叫張陵垦缅,是天一觀的道長。 經常有香客問我驹碍,道長壁涎,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 58,893評論 1 295
  • 正文 為了忘掉前任幸冻,我火速辦了婚禮粹庞,結果婚禮上,老公的妹妹穿的比我還像新娘洽损。我一直安慰自己庞溜,他們只是感情好,可當我...
    茶點故事閱讀 67,917評論 6 392
  • 文/花漫 我一把揭開白布碑定。 她就那樣靜靜地躺著流码,像睡著了一般。 火紅的嫁衣襯著肌膚如雪延刘。 梳的紋絲不亂的頭發(fā)上漫试,一...
    開封第一講書人閱讀 51,708評論 1 305
  • 那天,我揣著相機與錄音碘赖,去河邊找鬼驾荣。 笑死,一個胖子當著我的面吹牛普泡,可吹牛的內容都是我干的播掷。 我是一名探鬼主播,決...
    沈念sama閱讀 40,430評論 3 420
  • 文/蒼蘭香墨 我猛地睜開眼撼班,長吁一口氣:“原來是場噩夢啊……” “哼歧匈!你這毒婦竟也來了?” 一聲冷哼從身側響起砰嘁,我...
    開封第一講書人閱讀 39,342評論 0 276
  • 序言:老撾萬榮一對情侶失蹤件炉,失蹤者是張志新(化名)和其女友劉穎勘究,沒想到半個月后,有當地人在樹林里發(fā)現了一具尸體斟冕,經...
    沈念sama閱讀 45,801評論 1 317
  • 正文 獨居荒郊野嶺守林人離奇死亡口糕,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內容為張勛視角 年9月15日...
    茶點故事閱讀 37,976評論 3 337
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發(fā)現自己被綠了磕蛇。 大學時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片走净。...
    茶點故事閱讀 40,115評論 1 351
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖孤里,靈堂內的尸體忽然破棺而出,到底是詐尸還是另有隱情橘洞,我是刑警寧澤捌袜,帶...
    沈念sama閱讀 35,804評論 5 346
  • 正文 年R本政府宣布,位于F島的核電站炸枣,受9級特大地震影響虏等,放射性物質發(fā)生泄漏。R本人自食惡果不足惜适肠,卻給世界環(huán)境...
    茶點故事閱讀 41,458評論 3 331
  • 文/蒙蒙 一霍衫、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧侯养,春花似錦敦跌、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 32,008評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至辩稽,卻和暖如春惧笛,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背逞泄。 一陣腳步聲響...
    開封第一講書人閱讀 33,135評論 1 272
  • 我被黑心中介騙來泰國打工患整, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留,地道東北人喷众。 一個月前我還...
    沈念sama閱讀 48,365評論 3 373
  • 正文 我出身青樓各谚,卻偏偏與公主長得像,于是被迫代替她去往敵國和親侮腹。 傳聞我的和親對象是個殘疾皇子嘲碧,可洞房花燭夜當晚...
    茶點故事閱讀 45,055評論 2 355