vue怎样实现树形菜单

                    vue                                            *{                color:#585858;                     }            #app{                min-height:  650px;            }            #app li{                list-style-type:none;            }            #app a{                text-decoration:none;            }            #app button{                width:100%;            }            #app ul{                padding:10px;            }            #app span{                cursor:pointer;            }            #tree{                border: 1px solid #ccc;                            min-height:  650px;                width: 50%;                margin:0;                padding-top: 10px;                background-color:#f2f2f2;                position: absolute;                top:0;                left:0;            }                       #tree  li {                display: block;                padding: 0;                margin: 0;                border: 0;                border-bottom: 1px solid #e5e5e5;                min-height: 32px;                line-height:32px;            }                        

var data = [{"id":26,"pid":1,"city":"四川省"},{"id":30,"pid":1,"city":"云南省"},{"id":322,"pid":26,"city":"成都"},{"id":323,"pid":26,"city":"绵阳"},{"id":324,"pid":26,"city":"阿坝"},{"id":325,"pid":26,"city":"巴中"},{"id":326,"pid":26,"city":"达州"},{"id":327,"pid":26,"city":"德阳"},{"id":328,"pid":26,"city":"甘孜"},{"id":329,"pid":26,"city":"广安"},{"id":330,"pid":26,"city":"广元"},{"id":331,"pid":26,"city":"乐山"},{"id":332,"pid":26,"city":"凉山"},{"id":333,"pid":26,"city":"眉山"},{"id":334,"pid":26,"city":"南充"},{"id":335,"pid":26,"city":"内江"},{"id":336,"pid":26,"city":"攀枝花"},{"id":337,"pid":26,"city":"遂宁"},{"id":338,"pid":26,"city":"雅安"},{"id":339,"pid":26,"city":"宜宾"},{"id":340,"pid":26,"city":"资阳"},{"id":341,"pid":26,"city":"自贡"},{"id":342,"pid":26,"city":"泸州"},{"id":367,"pid":30,"city":"昆明"},{"id":378,"pid":30,"city":"曲靖"},{"id":3100,"pid":367,"city":"盘龙区"},{"id":3101,"pid":367,"city":"五华区"},{"id":3102,"pid":367,"city":"官渡区"},{"id":3103,"pid":367,"city":"西山区"},{"id":3104,"pid":367,"city":"东川区"},{"id":3105,"pid":367,"city":"安宁市"},{"id":3106,"pid":367,"city":"呈贡县"},{"id":3107,"pid":367,"city":"晋宁县"},{"id":3108,"pid":367,"city":"富民县"},{"id":3109,"pid":367,"city":"宜良县"},{"id":3110,"pid":367,"city":"嵩明县"},{"id":3111,"pid":367,"city":"石林县"},{"id":3112,"pid":367,"city":"禄劝"},{"id":3113,"pid":367,"city":"寻甸"},{"id":3189,"pid":378,"city":"麒麟区"},{"id":3190,"pid":378,"city":"宣威市"},{"id":3191,"pid":378,"city":"马龙县"},{"id":3192,"pid":378,"city":"陆良县"},{"id":3193,"pid":378,"city":"师宗县"},{"id":3194,"pid":378,"city":"罗平县"},{"id":3195,"pid":378,"city":"富源县"},{"id":3196,"pid":378,"city":"会泽县"},{"id":3197,"pid":378,"city":"沾益县"}]; var treeData = createTree({ idname:'id', pidname:'pid', rootid:1, data:data }); function createTree(arg){ var idname = arg.idname, pidname = arg.pidname, rootid = arg.rootid, data = arg.data, treeData = []; var _createTree = function(id){ var ret = []; var index = 0; for(var i = 0; i < data.length; i++){ if(data[i][pidname] == id){ ret[index] = data[i]; ret[index].child = _createTree(data[i][idname]); index++; } } return ret; } var index = 0; for(var i = 0; i < data.length; i++){ if(data[i][pidname] == rootid){ treeData[index] = data[i]; treeData[index].child = _createTree(data[i][idname]); index++; } } return treeData; } Vue.component('item', { template: '#tree-template', props: ['tree'], data: function () { return {} }, methods: { toggle: function (i) { this.tree[i].open = !this.tree[i].open; this.$set(this.tree, i, this.tree[i]); }, isFolder: function (data) { return data.child && data.child.length }, }, }) var vm = new Vue({ el: '#app', data: { treeData: treeData, show:false, }, methods: { hideTree:function(e){ if(e.target.id == 'app'){ console.log(137); this.show = false; } } }, created: function () { function _addOpen(data) { for (var i = 0; i 0) { _addOpen(data[i].child); } } } _addOpen(this.treeData); } });

登录后复制

相信看了本文案例你已经掌握了方法,更多精彩请关注【创想鸟】其它相关文章!

推荐阅读:

在前端中的html基础知识 

知名的网站前端布局分析

以上就是vue怎样实现树形菜单的详细内容,更多请关注【创想鸟】其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至253000106@qq.com举报,一经查实,本站将立刻删除。

发布者:PHP中文网,转转请注明出处:https://www.chuangxiangniao.com/p/2780785.html

(0)
上一篇 2025年3月8日 16:08:38
下一篇 2025年2月18日 06:45:31

AD推荐 黄金广告位招租... 更多推荐

相关推荐

  • Vue的计算属性

    这次给大家带来Vue的计算属性,使用Vue计算属性的注意事项有哪些,下面就是实战案例,一起来看一下。 Vue对象,按照现在的学习进度,可以分为: 其中el代表作用的HTML元素; data代表el中的所有数据; methods代表el中所有…

    2025年3月8日
    200
  • 实现微信UI的聊天功能

    这次给大家带来实现微信UI的聊天功能,实现微信UI的聊天功能的注意事项有哪些,下面就是实战案例,一起来看一下。 微信小程序最近很火,火到什么程度,只要你一打开微信,就是它的身影,几乎你用的各个APP都可以在微信中找到它的复制版,另外官方自带…

    2025年3月8日
    200
  • js中的日期实现方法

    本文主要和大家分享js中的日期实现方法,主要以代码的形式,希望能帮助到大家。 1.简单明了,直接new date(),然后就照着来就是了: var myDate = new Date(); myDate.getYear(); //获取当前年…

    编程技术 2025年3月8日
    200
  • 用js实现html转pdf

    这次给大家带来用js实现html转pdf,用js实现html转pdf的注意事项有哪些,下面就是实战案例,一起来看一下。 于是做了个小案例来测试这个功能。 生成PDF 登录后复制 js写法 window.onload =function(){…

    编程技术 2025年3月8日
    200
  • jquery 分页的两种实现方法

    本文主要和大家分享jquery pagination 分页的两种实现方法,此插件是jQuery的ajax分页插件。如果你用到此插件作分页的时候,涉及到的数据量大,可以采用异步加载数据,当数据不多的时候,直接一次性加载,方便简单。 一:下载地…

    编程技术 2025年3月8日
    200
  • 原生js实现轮播图

    本文主要和大家分享原生js实现轮播图,主要以代码形式,希望能帮助到大家。 nbsp;html>     /*重置样式*/ *{margin: 0;padding: 0; list-style: none;} /*wrap的轮播图和切换…

    编程技术 2025年3月8日
    200
  • vue.js实现单次弹框

    这次给大家带来vue.js实现单次弹框,vue.js实现单次弹框的注意事项有哪些,下面就是实战案例,一起来看一下。 核心代码是 getCookie()部分,控制弹框的显示隐藏则在 created()中。 Lorem ipsum dolor …

    编程技术 2025年3月8日
    200
  • 网页页面实现加载进度条

    这次给大家带来网页页面实现加载进度条,网页页面实现加载进度条的注意事项有哪些,下面就是实战案例,一起来看一下。 页面加载进度条最初我是在youtube上看到的,后面几乎在各大网站上都能见到它的身影,可以让用户在加载页面的时候不会对着完全空白…

    编程技术 2025年3月8日
    200
  • node+express实现聊天室

    这次给大家带来node+express实现聊天室,node+express实现聊天室的注意事项有哪些,下面就是实战案例,一起来看一下。 本篇文章使用node+express+jquery写一个个性化聊天室,一起来get一下~(源码地址见文章…

    2025年3月8日 编程技术
    200
  • Vue枚举类型实现HTML

    这次给大家带来Vue枚举类型实现HTML,Vue枚举类型实现HTML的注意事项有哪些,下面就是实战案例,一起来看一下。 下拉框包含option中的Value和用来显示的选项, 一般后台都是使用的Value值,而不是显示在前台的选项 第一步:…

    2025年3月8日
    200

发表回复

登录后才能评论