使用Vue递归组件实现动态菜单

  • 现在很多项目的菜单都是动态生成的,之前自己做项目也是遇到这种需求,翻看了官网案例,和网上大神的案例.只有两个感觉,官网的案例太简洁,没有什么注释,看起来不太好理解,大神们的作品又比较复杂,对于初学者来说理解起来还是有难度,自己捣鼓了几天,勉强理解了递归组件菜单的实现,这里结合官网的案例,把代码和注释附上.

  • 如果你的项目是element-ui,其实它里面也有提供树形菜单,但是由于是别人封装的,所以使用起来没那么方便,大多数还是会自己配置,好了,不说那么多,还是回到递归组件上来吧

  • 先来看一下菜单的最终效果,有+号的都是可以点击展开的
  •             
  • 首先看一下项目的目录,在后台菜单数据没拿到之前,这里先演示一个模拟数据的,先在SRC文档下建一个data存放菜单数据.按照菜单层级关系写 数据里设置menuLevel是为了配置路由的,值是组件的名字

  • 接着创建两个组件,一个是菜单父组件,一个是递归的子组件,父组件代码:

  • <template>
    <div>
    <ul id="demo">
    <submenu
    class="item"
    :model="treeData">
    </submenu>
    </ul>
    </div>
    </template>
    <script>
    // 引入菜单数据
    import data from '../../data/treeData'
    // 引入子组件
    import submenu from './submenu/submenu.vue'
    export default {
    components: {
    submenu
    },
    name: 'treeMenu',
    data () {
    return {
    treeData: data
    }
    }
    }
    </script>
    <style scoped>
    @import './treeMenu.scss';
    </style>
  • 子组件代码,html部分:
  • <template>
    <div>
    <li>
    <div
    :class="{bold: isFolder}"
    @click="toggle"
    @dblclick="changeType">
    <!-- 配置路由跳转 -->
    <router-link :to="{ name: model.menuLevel }">{{ model.name }}</router-link> <span v-if="isFolder">[{{ open ? '-' : '+' }}]</span>
    </div>
    <ul v-show="open" v-if="isFolder">
    <submenu
    class="item"
    v-for="(model, index) in model.children"
    :key="index"
    :model="model"> </submenu>
    <!-- <li class="add" @click="addChild">+</li> -->
    </ul>
    </li>
    </div>
    </template>

    子组件代码,js部分:

  • // 引入子组件
    import submenu from './submenu'
    export default {
    components: {
    submenu
    },
    name: 'submenu',
    props: {
    model: Object
    },
    data: function () {
    return {
    open: false
    }
    },
    computed: {
    // 是否展示+图标
    isFolder: function () {
    return this.model.children &&
    this.model.children.length
    }
    },
    methods: {
    // 单击展示子菜单
    toggle: function () {
    if (this.isFolder) {
    this.open = !this.open
    }
    },
    // 双击给当前单一不可展开的菜单添加children,变成可展开样式
    changeType: function () {
    if (!this.isFolder) {
    // Vue.set(this.model, 'children', [])
    this.$set(this.model, 'children', [])
    this.addChild()
    this.open = true
    }
    },
    // 给子菜单添加内容
    addChild: function () {
    this.model.children.push({
    name: 'new stuff'
    })
    }
    }
    }

    路由配置,这里的name和data数据里的menuLevel一样:

  • import Vue from 'vue'
    import Router from 'vue-router'
    // import OnePage from '@/components/OnePage/OnePage'
    // 引入菜单组件
    import treeMenu from '@/components/menu/treeMenu'
    // 引入一级菜单
    import one from '@/components/one/one'
    // 引入二级菜单
    import two from '@/components/two/two'
    // 引入三级菜单
    import three from '@/components/three/three' Vue.use(Router) export default new Router({
    routes: [
    // {
    // path: '/',
    // name: 'OnePage',
    // component: OnePage
    // }
    {
    path: '/',
    name: 'treeMenu',
    component: treeMenu
    },
    {
    path: '/one',
    name: 'one',
    component: one
    },
    {
    path: '/two',
    name: 'two',
    component: two
    },
    {
    path: '/three',
    name: 'three',
    component: three
    }
    ]
    })

    这样一个树形菜单就大致完成了,配置了路由的也可以跳转到相应页面,如果菜单数据是后台给你的,数据只要和你一开始设置data数据格式一样就可以直接用了

Vue.js递归组件实现动态树形菜单的更多相关文章

  1. 【Vue.js实战案例】- Vue.js递归组件实现组织架构树和选人功能

    大家好!先上图看看本次案例的整体效果. 浪奔,浪流,万里涛涛江水永不休.如果在jq时代来实这个功能简直有些噩梦了,但是自从前端思想发展到现在的以MVVM为主流的大背景下,来实现一个这样繁杂的功能简直不 ...

  2. Vue.js 递归组件实现树形菜单

    最近看了 Vue.js 的递归组件,实现了一个最基本的树形菜单. 项目结构: main.js 作为入口,很简单: import Vue from 'vue' Vue.config.debug = tr ...

  3. 用Vue.js递归组件构建一个可折叠的树形菜单

    在Vue.js中一个递归组件调用的是其本身,如: Vue.component('recursive-component', {   template: `<!--Invoking myself! ...

  4. Vue.js的组件(slot/动态组件等)、单文件组件、递归组件使用

    一.组件 1> 组件命名方式有两种(注意:在DOM模板中只有kebab-case命名方法才生效): html中引用组件: <!-- 在DOM模板中,只有 kebab-case命名才生效 - ...

  5. 【Vue课堂】Vue.js 父子组件之间通信的十种方式

    这篇文章介绍了Vue.js 父子组件之间通信的十种方式,不管是初学者还是已经在用 Vue 的开发者都会有所收获.无可否认,现在无论大厂还是小厂都已经用上了 Vue.js 框架,简单易上手不说,教程详尽 ...

  6. 谈谈Vue的递归组件

    2月最后一天,而且还四年一遇,然而本月居然一篇博客没写,有点说不过去.所以,今天就来谈谈Vue的递归组件.我们先来看一个例子: See the Pen 递归组件 by imgss (@imgss) o ...

  7. Vue.js多重组件嵌套

    Vue.js多重组件嵌套 Vue.js中提供了非常棒的组件化思想,组件提高了代码的复用性.今天我们来实现一个形如 <app> <app-header></app-head ...

  8. Vue.js之组件传值

    Vue.js之组件传值 属性传值可以从父组件到子组件,也可以从子组件到父组件. 这里讲一下从父组件到子组件的传值 还以上次的demo为例,demo里有APP.vue是父组件,Header.vue,Us ...

  9. Vue.js之组件嵌套小demo

    Vue.js之组件嵌套的小demo项目 第一步:初始化一个wabpack项目,这里不在复述.第二步:在components文件夹下新建Header.vue Footer.vue和Users.vue三个 ...

随机推荐

  1. linq组合查询时属性扩展问题

    学习linq的过程中,做一个表格的条件查询并且分页显示.显示的出的数据需要经过属性拓展来实现将需要给用户看的值显示出来. 后台绑定数据时用的是上下文---- if(!ispostback){ usin ...

  2. Zbar 大图像分析

    博客转载自:https://blog.csdn.net/sunflower_boy/article/details/50429252 为了减少处理时间,可以设定更大的扫描间距,减少不必要的解码类型,去 ...

  3. Boost中实现线程安全

    博客转载自: http://www.cnblogs.com/lvdongjie/p/4447142.html 1 boost原子变量和线程 #include <boost/thread.hpp& ...

  4. linux 开启终端256色支持

    一.简介 一般的Linux发行版默认的终端都是16色的,但事实上几乎所有的终端都支持256色终端.本文介绍开启终端256色支持的方法. 二.操作步骤 1)检查终端是否支持256色 http://www ...

  5. 11.树形Model/View实例

    任务1:显示如图的树形结构 思考: 1.使用QTreeView显示. 2.Model使用QStandardItemModel,qt的一个标准model. 3.QStandardItemModel下每一 ...

  6. linux环境安装python

    linux环境下安装python3,一步一步来吧! 安装python3 安装readline-devel依赖 ,用于解决python3安装完成后,退格和方向键乱码问题 yum install read ...

  7. SPOJ - AMR11H Array Diversity (水题排列组合或容斥)

    题意:给定一个序列,让你求两种数,一个是求一个子序列,包含最大值和最小值,再就是求一个子集包含最大值和最小值. 析:求子序列,从前往记录一下最大值和最小值的位置,然后从前往后扫一遍,每个位置求一下数目 ...

  8. HDU 5033 Building (维护单调栈)

    题目链接 题意:n个建筑物,Q条询问,问所在的位置,看到天空的角度是多少,每条询问的位置左右必定是有建筑物的. 思路 : 维护一个单调栈,将所有的建筑物和所有的人都放到一起开始算就行,每加入一个人,就 ...

  9. STL 堆的使用

    本来是要写leetcode上的merge k sorted lists那道题目,这个题目我还是很熟悉的,毕竟是看过算法导论的人,但是写的过程中对堆的维护代码还是挺多的,所以我想到了STL中的堆.下面就 ...

  10. c# XML增删改查

    using System; using System.Collections.Generic; using System.ComponentModel; using System.Data; usin ...