vue組件遞歸——級聯(lián)菜單的實現(xiàn)

最近做項目經(jīng)常會用到一些UI庫咆瘟,比如element汹忠、iview等把篓,這些能夠快速構(gòu)建應(yīng)用的庫真的十分方便。比如iview的級聯(lián)菜單很是好用乾蓬,但是在使用的同時不免起了一些疑惑,它是怎么做到多級聯(lián)動慎恒,依我所知任内,如果一個數(shù)據(jù)是多層的,我們就要多次使用v-for融柬,并且需要知道要循環(huán)幾次死嗦,但是這個組件貌似不需要多次復(fù)用。好啦粒氧,下面進入正題越除!

數(shù)據(jù)

首先我們手里是一份這樣的JSON數(shù)據(jù):

list: [
{
    "id": "1",
    "menuName": "項目管理",
    "childTree": [{
        "menuName": "項目進度",
        "childTree": [{
            "menuName": "項目一",
            "childTree": [{ "menuName": "詳細信息" }]
        }]
    }, {
        "menuName": "任務(wù)安排"
    }]
}, 
{
    "id": "2",
    "menuName": "數(shù)據(jù)統(tǒng)計"
}, 
{
    "id": "3",
    "menuName": "人員管理"
}]

子組件遞歸

這是最重要的環(huán)節(jié),組件的遞歸實現(xiàn)了級聯(lián)菜單的多級聯(lián)動外盯,這個過程就如同實現(xiàn)對象的深復(fù)制一樣摘盆。那么接下來我們按照這份數(shù)據(jù)寫一個遞歸組件:

// 子組件代碼
<template>
    <li>
        <span @click="toggle">
            {{ model.menuName }}
        </span>
        <ul v-if="isFolder" v-show="open">
            <items v-for="(item, index) in model.childTree" :model="item" :key="index"></items>
        </ul>
    </li>
</template>

<script type="text/javascript">
    export default {
        // 組件遞歸必要條件,name屬性
        name: 'items',
        props: ['model'],
        data() {
            return {
                // 控制子列表的顯示隱藏
                open: false
            }
        },
        computed: {
            // 是否還有子列表需要渲染饱苟,作為v-if的判斷條件
            isFolder() {
                return this.model.childTree && this.model.childTree.length
            }
        },
        methods: {
            // 切換列表顯示隱藏的方法
            toggle() {
                if(this.isFolder) {
                    this.open = !this.open
                }
            },
        }
    }
</script>

這里要強調(diào)以下孩擂,組件的name屬性必須要有,否則無法實現(xiàn)遞歸箱熬,當然遞歸也需要有終止的條件类垦,上邊的isFloder便是了狈邑。

父組件調(diào)用

<template>
    <div>
        <ul>
            <items v-for="(model, index) in list" :model="model" :key="index"></items>
        </ul>
    </div>
</template>

<script type="text/javascript">
    components: {
        Items
    },
    data() {
        return {
            list: ...
        }
    }
</script>

這里也有需要注意的,v-for循環(huán)需要綁定key蚤认,否則會報警告米苹。
最后來看下這個簡單級聯(lián)菜單的效果:

級聯(lián)列表

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市砰琢,隨后出現(xiàn)的幾起案子蘸嘶,更是在濱河造成了極大的恐慌,老刑警劉巖陪汽,帶你破解...
    沈念sama閱讀 218,941評論 6 508
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件亏较,死亡現(xiàn)場離奇詭異,居然都是意外死亡掩缓,警方通過查閱死者的電腦和手機雪情,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,397評論 3 395
  • 文/潘曉璐 我一進店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來你辣,“玉大人巡通,你說我怎么就攤上這事∩岷澹” “怎么了宴凉?”我有些...
    開封第一講書人閱讀 165,345評論 0 356
  • 文/不壞的土叔 我叫張陵,是天一觀的道長表悬。 經(jīng)常有香客問我弥锄,道長,這世上最難降的妖魔是什么蟆沫? 我笑而不...
    開封第一講書人閱讀 58,851評論 1 295
  • 正文 為了忘掉前任籽暇,我火速辦了婚禮,結(jié)果婚禮上饭庞,老公的妹妹穿的比我還像新娘戒悠。我一直安慰自己,他們只是感情好舟山,可當我...
    茶點故事閱讀 67,868評論 6 392
  • 文/花漫 我一把揭開白布绸狐。 她就那樣靜靜地躺著,像睡著了一般累盗。 火紅的嫁衣襯著肌膚如雪寒矿。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 51,688評論 1 305
  • 那天若债,我揣著相機與錄音符相,去河邊找鬼。 笑死拆座,一個胖子當著我的面吹牛主巍,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播挪凑,決...
    沈念sama閱讀 40,414評論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼孕索,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了躏碳?” 一聲冷哼從身側(cè)響起搞旭,我...
    開封第一講書人閱讀 39,319評論 0 276
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎菇绵,沒想到半個月后肄渗,有當?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 45,775評論 1 315
  • 正文 獨居荒郊野嶺守林人離奇死亡咬最,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 37,945評論 3 336
  • 正文 我和宋清朗相戀三年翎嫡,在試婚紗的時候發(fā)現(xiàn)自己被綠了。 大學時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片永乌。...
    茶點故事閱讀 40,096評論 1 350
  • 序言:一個原本活蹦亂跳的男人離奇死亡惑申,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出翅雏,到底是詐尸還是另有隱情圈驼,我是刑警寧澤,帶...
    沈念sama閱讀 35,789評論 5 346
  • 正文 年R本政府宣布望几,位于F島的核電站绩脆,受9級特大地震影響,放射性物質(zhì)發(fā)生泄漏橄抹。R本人自食惡果不足惜靴迫,卻給世界環(huán)境...
    茶點故事閱讀 41,437評論 3 331
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望楼誓。 院中可真熱鬧矢劲,春花似錦、人聲如沸慌随。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,993評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽阁猜。三九已至丸逸,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間剃袍,已是汗流浹背黄刚。 一陣腳步聲響...
    開封第一講書人閱讀 33,107評論 1 271
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留民效,地道東北人憔维。 一個月前我還...
    沈念sama閱讀 48,308評論 3 372
  • 正文 我出身青樓涛救,卻偏偏與公主長得像,于是被迫代替她去往敵國和親业扒。 傳聞我的和親對象是個殘疾皇子检吆,可洞房花燭夜當晚...
    茶點故事閱讀 45,037評論 2 355

推薦閱讀更多精彩內(nèi)容

  • Spring Cloud為開發(fā)人員提供了快速構(gòu)建分布式系統(tǒng)中一些常見模式的工具(例如配置管理,服務(wù)發(fā)現(xiàn)程储,斷路器蹭沛,智...
    卡卡羅2017閱讀 134,659評論 18 139
  • Android 自定義View的各種姿勢1 Activity的顯示之ViewRootImpl詳解 Activity...
    passiontim閱讀 172,167評論 25 707
  • 慣例早起,洗漱后坐在桌前準備化妝章鲤。手上還是熟悉的步驟摊灭,眼鏡看著鏡子,突然想起要給自己說說話败徊。 “對不起”帚呼,三個字說...
    萌巾閱讀 192評論 0 0
  • 京港澳高速新鄉(xiāng)段發(fā)生重大事故萝挤,受傷的有盛源的父母,讓人揪心根欧。 河南省公安廳高速交警總隊官方微博@河南高速公安通報稱...
    郭曉聞閱讀 549評論 4 4