这次给大家带来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;

}

点我

  • {{ tree[i].open ? '-' : '+' }}

    {{v.city}}

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 < data.length; i++) {

data[i]['open'] = false;

if (data[i].child.length > 0) {

_addOpen(data[i].child);

}

}

}

_addOpen(this.treeData);

}

});

相信看了本文案例你已经掌握了方法,更多精彩请关注php中文网其它相关文章!

推荐阅读:

vue树形权限菜单_vue实现树形菜单步骤说明相关推荐

  1. vue 左右滑动菜单_Vue实现左右菜单联动实现代码

    本文介绍了Vue实现左右菜单联动实现代码吗,分享给大家,也给自己留个笔记,具体如下: 之前在外卖软件上看到这个左右联动的效果,觉得很有意思,所以就尝试使用 Vue 来实现,将这个联动抽离成为一个单独的 ...

  2. vue 判断权限过期_vue 路由权限

    附上girhub 地址: loever/vue-FlexPaperViewer​github.com qq:3179689033 相互学习 我把router.js 分成router.js 和route ...

  3. vue 递归组件多级_Vue递归组件实现树形结构菜单

    Tree 组件是递归类组件的典型代表,它常用于文件夹.组织架构.生物分类.国家地区等等,世间万物的大多数结构都是树形结构.使用树控件可以完整展现其中的层级关系,并具有展开收起选择等交互功能. 如图所示 ...

  4. vue 递归组件多级_Vue 递归组件构建一个树形菜单

    原标题:Vue 递归组件构建一个树形菜单 Vue.js 中的递归组件是一个可以调用自己的组件例如: Vue.component('recursive-component', { template: ` ...

  5. java web 树形管理_java web 后台树形菜单排序

    1.需求场景 数据库后台返回树形结构菜单,实现菜单排序. 2.项目环境 spring spring mvc mybatis  mysql 3.实现方法 对应的实体类 private int id;// ...

  6. Vue.js iview实现树形权限表(可扩展表)

    问题: 需要一个可折叠的权限管理系统,用表格展示. 主要用的iView组件库,有Table(表格),Tree(树形控件),Collapse(折叠面板)看起来比较符合意思 深入查看Table相关范例,发 ...

  7. vue怎么实现右键二级菜单_vue中如何自定义右键菜单详解

    在所编辑的页面,需要添加右键菜单的元素,绑定contextmenu事件,如下: v-for="item in resourceList" :key="item.id&qu ...

  8. Vue人资中台--公司组织架构(树形结构)

    组织架构树形结构布局 目标:使用element-UI组件布局组织架构的基本布局 认识组织架构 组织架构产品prd 一个企业的组织架构是该企业的灵魂,组织架构多常采用树形金字塔式结构,本章节,我们布局出 ...

  9. Vue实战篇十六:导航菜单

    系列文章目录 Vue基础篇一:编写第一个Vue程序 Vue基础篇二:Vue组件的核心概念 Vue基础篇三:Vue的计算属性与侦听器 Vue基础篇四:Vue的生命周期(秒杀案例实战) Vue基础篇五:V ...

  10. html折叠菜单列子,基于Vue.js+bootstrap4的左侧可伸缩式菜单

    一.Vue.js简介 Vue (读音 /vjuː/,类似于 view) 是一套用于构建用户界面的渐进式框架.与其它大型框架不同的是,Vue 被设计为可以自底向上逐层应用.Vue 的核心库只关注视图层, ...

最新文章

  1. Scrapy框架的概念、作用和工作流程
  2. 深入浅出说编译原理(一)
  3. 如何在企业服务生态实现共赢?网易邀你共商智慧企业未来计划
  4. wxWidgets:wxSizerFlags类用法
  5. C++函数声明和定义
  6. Gstreamer编程
  7. python中str和int区别_python中eval与int的区别浅析
  8. java commons logging_Java日志介绍(5)-commons-logging
  9. MTK:串口学习和代码调试
  10. (二)pscc学习笔记
  11. SQL Nexus Tool
  12. 达梦数据库的表空间及用户管理
  13. 亚马逊云计算机配置,亚马逊云教程6:创建、启动AMI,设置Cloud Watch
  14. JavaTutorials之Operators
  15. 小米11的root过程记录
  16. 启动界面、封面图片、Splash关不掉,一直转圈,无法进入
  17. bm算法好后缀 java实现_BM算法 | Depeng's Blog
  18. 【知识兔】Excel查找替换的6大典型用法
  19. 联发科有没有高端处理器_联发科处理器哪些好 2019联发科处理器排名
  20. 3万字BI系统整体建设解决方案

热门文章

  1. IT6801FN图像质量调优
  2. java基础:运算符
  3. java 基础:方法/函数
  4. 小项目之个人银行账户管理程序(1)
  5. C++改Java——个人银行账户管理
  6. 用matlab怎么仿真升降压电路,(最新整理)升降压斩波电路matlab仿真
  7. php后端开发需要懂什么意思,PHP中的=什么意思?_后端开发
  8. 手机后端开发用php,【后端开发】php如何获取手机型号
  9. 【高级数据结构】线段树 | 求区间和
  10. python神经网络预测股票组合_神经网络预测股票市场