vue做出树形菜单步骤详解

这次给大家带来vue做出树形菜单步骤详解,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); } });

登录后复制

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

推荐阅读:

react-native封装插件swiper使用步骤详解

FIFO/LRU实现缓存算法

以上就是vue做出树形菜单步骤详解的详细内容,更多请关注【创想鸟】其它相关文章!

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

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

(0)
上一篇 2025年3月8日 10:04:44
下一篇 2025年3月7日 00:00:24

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

相关推荐

  • vue实现树形菜单步骤说明

    这次给大家带来vue实现树形菜单步骤说明,vue实现树形菜单的注意事项有哪些,下面就是实战案例,一起来看一下。 vue *{ color:#585858; } #app{ min-height: 650px; } #app li{ list…

    编程技术 2025年3月8日
    200
  • jQuery替换节点元素步骤详解

    这次给大家带来jQuery替换节点元素步骤详解,jQuery替换节点元素的注意事项有哪些,下面就是实战案例,一起来看一下。 替换节点元素的操作,实现动态页面的,代码如下 中国 $(document).ready(function () { …

    2025年3月8日
    200
  • JS原型与原型链使用详解

    这次给大家带来JS原型与原型链使用详解,JS原型与原型链使用的注意事项有哪些,下面就是实战案例,一起来看一下。 我们创建的每个函数都有一个 prototype (原型)属性,这个属性是一个指针,指向一个原型对象,而这个原型对象中拥有的属性和…

    2025年3月8日
    200
  • Vue动态创建与删除数据步骤详解

    这次给大家带来Vue动态创建与删除数据步骤详解,Vue动态创建与删除数据的注意事项有哪些,下面就是实战案例,一起来看一下。 视图: 代码如下: //导入vue.js //非常简单了设置了一下css样式 #app{ height: 100%;…

    2025年3月8日
    200
  • vue1与vue2获取dom元素步骤详解

    这次给大家带来vue1与vue2获取dom元素步骤详解,vue1与vue2获取dom元素的注意事项有哪些,下面就是实战案例,一起来看一下。 vue1.*版本中 在标签中加上el=’dom’,然后在代码中this.$e…

    编程技术 2025年3月8日
    200
  • aggregate级联查询实现步骤

    这次给大家带来aggregate级联查询实现步骤,aggregate级联查询实现的注意事项有哪些,下面就是实战案例,一起来看一下。 最近完成了一个nodejs+mongoose的项目,碰到了mongodb的级联查询操作。情形是实现一个排行榜…

    编程技术 2025年3月8日
    200
  • vue请求数据后再渲染dom步骤详解

    这次给大家带来vue请求数据后再渲染dom步骤详解,vue请求数据后再渲染dom的注意事项有哪些,下面就是实战案例,一起来看一下。 在项目中遇到了一个问题,下面是vue template中的代码: 我之前的写法是 这样做的结果是下面取dom…

    2025年3月8日
    200
  • vue激活当前路由步骤详解

    这次给大家带来vue激活当前路由步骤详解,vue激活当前路由的注意事项有哪些,下面就是实战案例,一起来看一下。 一个 route object(路由信息对象) 表示当前激活的路由的状态信息,包含了当前 URL 解析得到的信息,还有 URL …

    2025年3月8日
    200
  • Vue路由导航菜单栏高亮实现方法

    这次给大家带来Vue路由导航菜单栏高亮实现方法,Vue路由导航菜单栏高亮实现的注意事项有哪些,下面就是实战案例,一起来看一下。 默认情况下,路由的导航菜单,会自动给当前菜单添加router-link-exact-active 和router…

    编程技术 2025年3月8日
    200
  • axios+post方法提交formdata步骤详解

    这次给大家带来axios+post方法提交formdata步骤详解,axios+post方法提交formdata的注意事项有哪些,下面就是实战案例,一起来看一下。 vue框架推荐使用axios来发送ajax请求,之前我还写过一篇博客来讲解如…

    2025年3月8日 编程技术
    200

发表回复

登录后才能评论