具有增、删、改、查功能的vue-tree树组件

最近写了一个具有增删改查功能的多级树组件,感觉很实用,啦啦啦啦,

废话不多说,看代码:

tree.vue

  1 <template>
  2   <div>
  3     <div class="all-div" v-if="model.name">
  4       <div class="itemRow" :style="{ marginLeft:model.level*20+‘px‘ }">
  5         <span v-show="model.children.length" @click="expandOrCollapse">
  6           <img v-if="model.isOpen" src="../../static/img/down.png">
  7           <img v-else src="../../static/img/right.png">
  8         </span>
  9         <div class="hover-div" @mouseover="flag=true" @mouseout="flag=false">
 10           <span @click="jump(model.url)">{{model.name}}</span>
 11           <span v-show="flag==true" @click="add"><img src="../../static/img/add.png"></span>
 12           <span v-show="flag==true" @click="remove(model)"><img src="../../static/img/delete.png"></span>
 13           <span v-show="flag==true" @click="edit"><img src="../../static/img/edit.png"></span>
 14           <!--<span class="asce" v-show="model.children.length" @click="orderAsce">↑</span>
 15         <span class="desc" v-show="model.children.length" @click="orderDesc">↓</span>-->
 16         </div>
 17
 18       </div>
 19     </div>
 20     <navigation v-if="model.isOpen" v-for="row in model.children" :key="row.name" :model="row" :length="model.children.length"></navigation>
 21   </div>
 22 </template>
 23
 24 <script>
 25   export default {
 26     name: ‘navigation‘,
 27     // 使用`编辑树`组件需要传递的数据
 28     props: {
 29       // 编辑树对象
 30       model: {
 31         type: Object
 32       },
 33
 34       length: {
 35         type: Number
 36       }
 37     },
 38
 39     data () {
 40       return {
 41         flag:false
 42
 43       }
 44     },
 45
 46     methods: {
 47       // 添加节点
 48       add(){
 49         let val = prompt("请输入要添加的节点的名称:");
 50         if (val) {
 51           this.model.children.push({
 52             name: val,
 53             level: this.model.level + 1,
 54             isOpen: true,
 55             children: []
 56           });
 57         }
 58
 59       },
 60
 61       // 移除节点
 62       remove(model){
 63         var self = this;
 64         alert(‘确认删除吗?‘);
 65         if (self.$parent.model) {
 66           self.$parent.model.children.forEach((item, index) => {
 67             if (item.name == model.name) {
 68             self.$parent.model.children.splice(index, 1);
 69           }
 70         })
 71         }
 72       },
 73
 74       // 编辑节点名称
 75       edit(){
 76         var self = this;
 77         let rename = prompt(‘请输入修改后的节点名称:‘);
 78         // 使用正则进行重命名的差错校验
 79         if (!rename.length) {
 80           alert(‘请输入正确的节点名称‘);
 81           return;
 82         }
 83         self.model.name = rename;
 84       },
 85
 86       /**
 87        * 展开/收起功能
 88        */
 89       expandOrCollapse(){
 90         this.model.isOpen = !this.model.isOpen;
 91       },
 92       jump(url){
 93         var self = this;
 94         self.$router.push({path:url})
 95       }
 96
 97       /*// 升序排列
 98        orderAsce(){
 99        function compare(property) {
100        return function (a, b) {
101        var value1 = a[property];
102        var value2 = b[property];
103        return value1 - value2;
104        }
105        }
106        this.model.children.sort(compare(‘name‘));
107        },
108
109        // 降序排列
110        orderDesc(){
111        this.orderAsce();
112        this.model.children.reverse();
113        }*/
114     },
115   }
116 </script>
117
118 <!-- Add "scoped" attribute to limit CSS to this component only -->
119 <style scoped>
120   .all-div{
121     margin-left: 6%;
122
123   }
124   .itemRow {
125     text-align: left;
126     padding-top: 2%;
127     padding-bottom: 2%;
128   }
129   .itemRow span,.itemRow img{
130     cursor: pointer;
131   }
132   .itemRow span{
133     font-size: 1.1vw;
134   }
135   .hover-div{
136     display:inline-block;
137   }
138
139
140 </style>

父组件代码如下:

leftNavigation.vue

 1 <template>
 2   <div id="all">
 3     <tree :model="root" :length="length"></tree>
 4   </div>
 5 </template>
 6 <style scoped>
 7   #all{
 8     width:100%;
 9     height: 100%;
10   }
11
12 </style>
13 <script>
14   import tree from ‘./tree.vue‘
15   export default{
16     data(){
17       return{
18         root:{
19           name:"根节点",
20           level:0,
21           isOpen:true,
22           children:[
23             {
24               name:"节点1",
25               level:1,
26               url:"/homePage/middle/navLeftFirst",
27               isOpen:false,
28               children:[
29                 {
30                   name:"节点1-1",
31                   level:2,
32                   isOpen:true,
33                   children:[]
34                 },
35                 {
36                   name:"节点1-2",
37                   level:2,
38                   isOpen:true,
39                   children:[]
40                 }
41               ]
42             },
43             {
44               name:"节点2",
45               level:1,
46               url:"/homePage/middle/navLeftSecond",
47               isOpen:false,
48               children:[
49                 {
50                   name:"节点2-1",
51                   level:2,
52                   isOpen:true,
53                   children:[]
54                 },
55                 {
56                   name:"节点2-2",
57                   level:2,
58                   isOpen:true,
59                   children:[]
60                 }
61               ]
62
63             }
64           ]
65         },
66         length:2
67       }
68     },
69     components:{
70       tree
71     }
72   }
73 </script>
时间: 2024-09-30 10:49:31

具有增、删、改、查功能的vue-tree树组件的相关文章

Python---MySQL数据库之四大操作(增 删 改 查)

一.对数据库,表,记录---四大操作(增 删 改 查) 1.操作数据库 (1)对数据库(文件夹):进行增加操作 Create  database  库名; 例:  Create  database  db7 ; 查询库: show  databases; 结果: +-----------------------------+ | Database                   | +----------------------------+ | information_schema | |

ADO.NET 增 删 改 查

ADO.NET:(数据访问技术)就是将C#和MSSQL连接起来的一个纽带 可以通过ADO.NET将内存中的临时数据写入到数据库中 也可以将数据库中的数据提取到内存中供程序调用 ADO.NET所有数据访问技术的基础 连接数据库基本格式:需要两个类1.数据库连接类 SqlConnection2.数据库操作类 SqlCommand 1.连接数据库写连接字符串,立马就要想到有4点要写完,1.连接哪台服务器,2.连接哪个数据库,3.连接用户名,4.密码string sql = "server=.(服务器i

oracle 11g 建库 建表 增 删 改 查 约束

一.建库 1.(点击左上角带绿色+号的按钮) 2.(进入这个界面,passowrd为密码.填写完后点击下面一排的Test按钮进行测试,无异常就点击Connect) 二.建表 1-1. create table 表名1( Tid number(4) --primary key 列级约束(主键), Tname varchar(10) --ont null  非空约束,只能定义在列级约束, Tsex varchar2(2)--check (tsex='男'  or  tsex='女') 检查约束, T

数据库基础学习4--表格的 增 删 改 查(简单查询与高级查询)

一.增 C:create 增加,创建,向数据库里面添加数据. insert into Fruit values('K009','苹果',3.0,'高青',90,'') insert into Fruit(Ids,Name,Price,Source,Numbers) values('K010','苹果',3.0,'高青',90) 二.改 U:update修改,从数据库表里面修改数据. update Fruit set Source='烟台' where Ids='K001' 三.删 D:delet

SQL 增/删/改/查 (总结)

1.增 INSERT  INTO  表名  VALUES (" "," ") ; INSERT INTO 表名(字段)  VALUES(" "); 2. 删 DELETE   FROM 表名  WHERE  ... 3.改 UPDATE  表名 SET   ... WHERE  ... 4.查 SELECT × FROM  表名 ORDER BY ...

1-24.list的增,删,改,查

增: 1.append(通过元素增加,默认加在最后print(a.append('hgf'))) 2.extend( 迭代的去增,就是把字符串的字符逐个去给这个列表加上去) 3.insert((按照索引去增加,前为索引,后为增加的字) 删: 1,pop(通过位置索引去删除) 2.del (通过索引,切片删除) 3.clear(清空列表) 4.remove(通过元素去删除) #返回值是什么意思? 改: a[]='i' print() 查: for i in a: print(a) 其他列表 1.s

php基础:数据库的含义和基本操作 增 删 改 查

//数据库是帮我们管理数据的一个软件,我们将数据给他,放进数据库里.他能很稳妥的帮我们管理起来,且效率很高.//php的大部分工作就是  php->连接数据库->写入数据->查出数据->格式化数据->显示出来,//数据库管理数据是以表的形式组成的,多行多列,表头声明好了,一个表创建好了,剩下的就是往里面添加数据 多张表放在一个文件夹里面就形成了库  mysql服务器帮我们管理多个库C:\wamp\bin\mysql\mysql5.6.12\data   数据库中的数据放在这个

Android 增,删,改,查 通讯录中的联系人

一.权限 操作通讯录必须在AndroidManifest.xml中先添加2个权限, <uses-permission android:name="android.permission.READ_CONTACTS"></uses-permission> <uses-permission android:name="android.permission.WRITE_CONTACTS"></uses-permission>

js数组的管理[增,删,改,查]

今天在设计表单的时候遇到对数组的一些处理的问题,比如说怎么创建一个数组,然后牵扯到数组的增删改查的方法.请看API FF: Firefox, N: Netscape, IE: Internet Explorer 方法 描述 FF N IE concat() 连接两个或更多的数组,并返回结果. 1 4 4 join() 把数组的所有元素放入一个字符串.元素通过指定的分隔符进行分隔. 1 3 4 pop() 删除并返回数组的最后一个元素 1 4 5.5 push() 向数组的末尾添加一个或更多元素,

数据操作:增 删 改 查

1.创建数据库create database 库名gouse 库名go 2.创建表 create table 表名 ( 列名 类型, 列名 类型, 列名 类型 ) 例子: create table one( daihao varchar(10), shuming varchar(50), zuozhe varchar(10), chubanshe varchar(50), shijian datetime) 3.添加行记录 insert into 表名(列名,列名,列名) values('值',