• 递归组件


    递归组件

      组件在它的模板内可以递归地调用自己,只有当它有 name 选项时才可以。 在官网这句话就是关键定义组件是一定要有name属性。按照这个思路我们开动吧。

      实现最终效果图:

        

      模拟数据格式如下:

        

    复制代码
    var data = [{
                    "id": "1",
                    "data": {
                        "menuName": "项目管理",
                        "menuCode": "",
                    },
                    "childTreeNode": [{
                        "data": {
                            "menuName": "项目",
                            "menuCode": "BusProject",
                        },
                        "childTreeNode": []
                    }, {
                        "data": {
                            "menuName": "我的任务",
                            "menuCode": "BusProject",
                        },
                        "childTreeNode": []
                    }, {
                        "data": {
                            "menuName": "人员周报",
                            "menuCode": "BusProject",
                        },
                        "childTreeNode": []
                    }]
                }, {
                    "id": "2",
                    "data": {
                        "menuName": "数据统计",
                        "menuCode": "BusClock",
                    },
                    "childTreeNode": []
                }, {
                    "id": "3",
                    "data": {
                        "menuName": "人事管理",
                        "menuCode": "",
                    },
                    "childTreeNode": []
                }, {
                    "id": "4",
                    "data": {
                        "menuName": "基础管理",
                        "menuCode": "",
                    },
                    "childTreeNode": []
                }]
    复制代码

    html我们思路按照ul里面套li,无限ul套li,标题用div元素包裹,

    复制代码
    <li>
        <div @click='toggle'>
       <i v-if='isFolder' class="fa " :class="[open?'fa-folder-open':'fa-folder']"></i>
         <!--isFolder判断是否存在子级改变图标--> <i v-if='!isFolder' class="fa fa-file-text"></i> {{model.data.menuName}} </div> <ul v-show="open" v-if='isFolder'> <items v-for='cel in model.childTreeNode' :model='cel'></items> </ul>
    </li>
    复制代码

    官方文档里面写的递归组件强调了使用name属性

    export default {
        name: 'items',
        props: ['model'],
        components: {},
    }

    按照vue的思想,不操作Dom树,我们定义两个变量,一个显示隐藏子菜单(open),一个存不存子菜单修改图标(isFolder)。

    data() {
            return {
                 open: false,
                 isFolder: true
            }
    }

    利用vue计算属性动态改变isFolder的值,修改图标,判断存在不子级和子级长度

    computed: {
        isFolder() {
            return this.model.childTreeNode && this.model.childTreeNode.length
        }
    }        

    显示隐藏事件

    复制代码
    methods: {
      toggle: function() { if(this.isFolder) { this.open = !this.open }   }
    }
    复制代码

    写到这里我们已经做完一个树形菜单了如下,最终样式就留给大家自己去实现了我在贴出完整代码供大家参考。

    复制代码
    <template>
        <li>
            <div @click='toggle'>
                <i v-if='isFolder' class="fa " :class="[open?'fa-folder-open':'fa-folder']"></i>
                <!--isFolder判断是否存在子级改变图标-->
                <i v-if='!isFolder' class="fa fa-file-text"></i> {{model.data.menuName}}
            </div>
            <ul v-show="open" v-if='isFolder'>
                <items v-for='cel in model.childTreeNode' :model='cel'></items>
            </ul>
        </li>
    </template>
    <script type="text/javascript">
        export default {
            name: 'items',
            props: ['model'],
            components: {},
            data() {
                return {
                    open: false,
                    isFolder: true
                }
            },
            computed: {
                isFolder: function() {
                    return this.model.childTreeNode && this.model.childTreeNode.length
                }
            },
            methods: {
                toggle: function() {
                    if(this.isFolder) {
                        this.open = !this.open
                    }
                },
            }
        }
    </script>
    复制代码

    公司最开始是使用easyui做的管理系统,我接手后用vue完整模仿了一些easyui的东西,下面就是在树形菜单基础上模仿出了树形表格,对此感兴趣或者需要的可以联系我。下图为完整图

    转发自:http://www.cnblogs.com/ychl/

  • 相关阅读:
    PC远程调试设备(转)
    根据自己的需要,把别人开发好的东西搬过来,优化and重构,在优化的过程中,甚至也会弄出一套全新的东西(转)
    修改Hosts不生效的一个场景-web 专题
    Data URI(转)
    数据仓库与数据挖掘的一些基本概念
    几种常见模式识别算法整理和总结
    史上最简单的Hibernate入门简单介绍
    sprintf,你知道多少?
    一步一步写算法(之洗牌算法)
    ListView的优化
  • 原文地址:https://www.cnblogs.com/lzbk/p/6078983.html
Copyright © 2020-2023  润新知