vue+elementui 将后端传来数据编程tree结构、同一级别数据对象

前端目标代码:

     <ul v-loading="loading">        
<li v-for="(item, index) in options" :key="index" :style="{ cursor: item.tic_parent_id != 0 ? 'pointer' : '' }" :class="checkItemId == item.tic_id ? 'checkItem' : ''" @click="checkItem(item)" v-if="item.tic_parent_id === 0 || item.bool">
// bool true 展开 false 合上 <span> <span class="iocn_span"> <i @click.stop="isShrink(item)" v-if="item.tic_parent_id == 0" :class="item.isbool ? 'icon-jian' : 'icon-jia-'" class="iconfont"></i> </span> <span class="iocn_span" v-if="item.tic_parent_id != 0"></span>{{ item.tic_name }} </span> <!-- 编辑、删除 --> <span class="li_right"> <i v-if="$hasPerm('message:edit')" @click.stop="sysmenuEdit(item)" class="iconfont icon-bianji"></i> <i v-if="$hasPerm('message:remove')" @click.stop="handleDelete(item)" class="iconfont icon-shanchushaixuanxiang"></i> </span> </li> </ul>

methods:

// 分类列表
    getOptation () {
      let that = this
      that.loading = true
      this.$post('/TbInfromationController/list', {
        page: 1,
        pageSize: 99999
      })
        .then(res => {
          that.loading = false
          if (res.code === 100) {
            let options = that.treeTable(res.data) // 改成上下级关系
            that.options = that.editDate(options) //  改成同级以便li显示
          } else {
            that.$message.info(res.message)
          }
        })
        .catch(res => {
          that.loading = false
        })
    },
    treeTable (data) {
      let newData = new Array()
      data.map(item => {
        if (item.tic_parent_id === 0) {
          newData.push(item)
        }
      })
      if (newData.length <= 0) {
        return data
      }
      newData.map(item => {
        item['children'] = []
        data.map(childrenitem => {
          if (item.tic_id === childrenitem.tic_parent_id) {
            item.children.push(childrenitem)
          }
        })
      })
      console.log(newData, data)
      return newData
    },
   // 类别数据处理
    editDate (data) {
      let array = []
      if (data.length) {
        data.map(item => {
          item['isbool'] = true
          array.push(item)
          if (item.children && item.children.length) {
            item.children.map(item_ch => {
              item_ch['bool'] = true
              array.push(item_ch)
            })
          }
        })
      }
      return array
    },

   isShrink (item) {
      console.log(item)
      console.log(this.options)
      item['isbool'] = !item['isbool']
      if (item.isbool) {
        this.options.map(dataitem => {
          if (dataitem.tic_parent_id === item.tic_id) {
            dataitem['bool'] = true
          }
        })
      } else {
        this.options.map(dataitem => {
          if (dataitem.tic_parent_id === item.tic_id) {
            dataitem['bool'] = false
          }
        })
      }
      this.$forceUpdate()
    },
isShrink 控制的是列表的展示与合并

 

 

 

1、后台传来数据

[
{
bool: true
name: "ivan1"
tic_add_date: "2020-09-14 17:36:39"
tic_id: 22
tic_name: "111"
tic_parent_id: 16
tic_user_id: 1
__ob__: Observer {value: {…}, dep: Dep, vmCount: 0}
get name: ƒ reactiveGetter()
set name: ƒ reactiveSetter(newVal)
get tic_add_date: ƒ reactiveGetter()
set tic_add_date: ƒ reactiveSetter(newVal)
get tic_id: ƒ reactiveGetter()
set tic_id: ƒ reactiveSetter(newVal)
get tic_name: ƒ reactiveGetter()
set tic_name: ƒ reactiveSetter(newVal)
get tic_parent_id: ƒ reactiveGetter()
set tic_parent_id: ƒ reactiveSetter(newVal)
get tic_user_id: ƒ reactiveGetter()
set tic_user_id: ƒ reactiveSetter(newVal)
__proto__: Object
},
{
bool: true
name: "ivan1"
tic_add_date: "2020-09-14 17:27:44"
tic_id: 20
tic_name: "分类标题1-1"
tic_parent_id: 16
tic_user_id: 1
__ob__: Observer {value: {…}, dep: Dep, vmCount: 0}
get name: ƒ reactiveGetter()
set name: ƒ reactiveSetter(newVal)
get tic_add_date: ƒ reactiveGetter()
set tic_add_date: ƒ reactiveSetter(newVal)
get tic_id: ƒ reactiveGetter()
set tic_id: ƒ reactiveSetter(newVal)
get tic_name: ƒ reactiveGetter()
set tic_name: ƒ reactiveSetter(newVal)
get tic_parent_id: ƒ reactiveGetter()
set tic_parent_id: ƒ reactiveSetter(newVal)
get tic_user_id: ƒ reactiveGetter()
set tic_user_id: ƒ reactiveSetter(newVal)
__proto__: Object
}
]

2、分级后数据

[
{
children: Array(2)
[{
bool: true
name: "ivan1"
tic_add_date: "2020-09-14 17:36:39"
tic_id: 22
tic_name: "111"
tic_parent_id: 16
tic_user_id: 1
}
{
bool: true
name: "ivan1"
tic_add_date: "2020-09-14 17:27:44"
tic_id: 20
tic_name: "分类标题1-1"
tic_parent_id: 16
tic_user_id: 1
}
length: 2
],
isbool: true
name: "ivan1"
tic_add_date: "2020-09-14 16:44:08"
tic_id: 16
tic_name: "分类标题1"
tic_parent_id: 0
tic_user_id: 1
},
{
children: Array(1)
[{
bool: true
name: "ivan1"
tic_add_date: "2020-09-14 15:12:59"
tic_id: 15
tic_name: "111"
tic_parent_id: 14
tic_user_id: 1
length: 1
}]
isbool: true
name: "ivan1"
tic_add_date: "2020-09-11 16:59:26"
tic_id: 14
tic_name: "1122"
tic_parent_id: 0
tic_user_id: 1
}
]

 

 

 

   

3、将分级后数据变成同一级(方便<li>获取数据)

(13) [{…}, {…}, {…}, {…}, {…}, {…}, {…}, {…}, {…}, {…}, {…}, {…}, {…}, __ob__: Observer]
0:
children: Array(2)
isbool: true
name: "ivan1"
tic_add_date: "2020-09-14 16:44:08"
tic_id: 16
tic_name: "分类标题1"
tic_parent_id: 0
tic_user_id: 1
__ob__: Observer {value: {…}, dep: Dep, vmCount: 0}
get children: ƒ reactiveGetter()
set children: ƒ reactiveSetter(newVal)
get name: ƒ reactiveGetter()
set name: ƒ reactiveSetter(newVal)
get tic_add_date: ƒ reactiveGetter()
set tic_add_date: ƒ reactiveSetter(newVal)
get tic_id: ƒ reactiveGetter()
set tic_id: ƒ reactiveSetter(newVal)
get tic_name: ƒ reactiveGetter()
set tic_name: ƒ reactiveSetter(newVal)
get tic_parent_id: ƒ reactiveGetter()
set tic_parent_id: ƒ reactiveSetter(newVal)
get tic_user_id: ƒ reactiveGetter()
set tic_user_id: ƒ reactiveSetter(newVal)
__proto__: Object
1:
bool: true
name: "ivan1"
tic_add_date: "2020-09-14 17:36:39"
tic_id: 22
tic_name: "111"
tic_parent_id: 16
tic_user_id: 1
__ob__: Observer {value: {…}, dep: Dep, vmCount: 0}
get name: ƒ reactiveGetter()
set name: ƒ reactiveSetter(newVal)
get tic_add_date: ƒ reactiveGetter()
set tic_add_date: ƒ reactiveSetter(newVal)
get tic_id: ƒ reactiveGetter()
set tic_id: ƒ reactiveSetter(newVal)
get tic_name: ƒ reactiveGetter()
set tic_name: ƒ reactiveSetter(newVal)
get tic_parent_id: ƒ reactiveGetter()
set tic_parent_id: ƒ reactiveSetter(newVal)
get tic_user_id: ƒ reactiveGetter()
set tic_user_id: ƒ reactiveSetter(newVal)
__proto__: Object
2:
bool: true
name: "ivan1"
tic_add_date: "2020-09-14 17:27:44"
tic_id: 20
tic_name: "分类标题1-1"
tic_parent_id: 16
tic_user_id: 1
__ob__: Observer {value: {…}, dep: Dep, vmCount: 0}
get name: ƒ reactiveGetter()
set name: ƒ reactiveSetter(newVal)
get tic_add_date: ƒ reactiveGetter()
set tic_add_date: ƒ reactiveSetter(newVal)
get tic_id: ƒ reactiveGetter()
set tic_id: ƒ reactiveSetter(newVal)
get tic_name: ƒ reactiveGetter()
set tic_name: ƒ reactiveSetter(newVal)
get tic_parent_id: ƒ reactiveGetter()
set tic_parent_id: ƒ reactiveSetter(newVal)
get tic_user_id: ƒ reactiveGetter()
set tic_user_id: ƒ reactiveSetter(newVal)
__proto__: Object
3:
children: Array(1)
0:
bool: true
name: "ivan1"
tic_add_date: "2020-09-14 15:12:59"
tic_id: 15
tic_name: "111"
tic_parent_id: 14
tic_user_id: 1
__ob__: Observer {value: {…}, dep: Dep, vmCount: 0}
get name: ƒ reactiveGetter()
set name: ƒ reactiveSetter(newVal)
get tic_add_date: ƒ reactiveGetter()
set tic_add_date: ƒ reactiveSetter(newVal)
get tic_id: ƒ reactiveGetter()
set tic_id: ƒ reactiveSetter(newVal)
get tic_name: ƒ reactiveGetter()
set tic_name: ƒ reactiveSetter(newVal)
get tic_parent_id: ƒ reactiveGetter()
set tic_parent_id: ƒ reactiveSetter(newVal)
get tic_user_id: ƒ reactiveGetter()
set tic_user_id: ƒ reactiveSetter(newVal)
__proto__: Object
length: 1
__ob__: Observer {value: Array(1), dep: Dep, vmCount: 0}
__proto__: Array
isbool: true
name: "ivan1"
tic_add_date: "2020-09-11 16:59:26"
tic_id: 14
tic_name: "1122"
tic_parent_id: 0
tic_user_id: 1
__ob__: Observer {value: {…}, dep: Dep, vmCount: 0}
get children: ƒ reactiveGetter()
set children: ƒ reactiveSetter(newVal)
get name: ƒ reactiveGetter()
set name: ƒ reactiveSetter(newVal)
get tic_add_date: ƒ reactiveGetter()
set tic_add_date: ƒ reactiveSetter(newVal)
get tic_id: ƒ reactiveGetter()
set tic_id: ƒ reactiveSetter(newVal)
get tic_name: ƒ reactiveGetter()
set tic_name: ƒ reactiveSetter(newVal)
get tic_parent_id: ƒ reactiveGetter()
set tic_parent_id: ƒ reactiveSetter(newVal)
get tic_user_id: ƒ reactiveGetter()
set tic_user_id: ƒ reactiveSetter(newVal)
__proto__: Object
4:
bool: true
name: "ivan1"
tic_add_date: "2020-09-14 15:12:59"
tic_id: 15
tic_name: "111"
tic_parent_id: 14
tic_user_id: 1
__ob__: Observer {value: {…}, dep: Dep, vmCount: 0}
get name: ƒ reactiveGetter()
set name: ƒ reactiveSetter(newVal)
get tic_add_date: ƒ reactiveGetter()
set tic_add_date: ƒ reactiveSetter(newVal)
get tic_id: ƒ reactiveGetter()
set tic_id: ƒ reactiveSetter(newVal)
get tic_name: ƒ reactiveGetter()
set tic_name: ƒ reactiveSetter(newVal)
get tic_parent_id: ƒ reactiveGetter()
set tic_parent_id: ƒ reactiveSetter(newVal)
get tic_user_id: ƒ reactiveGetter()
set tic_user_id: ƒ reactiveSetter(newVal)
__proto__: Object
5:
children: Array(0)
isbool: true
name: "ivan1"
tic_add_date: "2020-09-11 16:54:24"
tic_id: 12
tic_name: "11"
tic_parent_id: 0
tic_user_id: 1
__ob__: Observer {value: {…}, dep: Dep, vmCount: 0}
get children: ƒ reactiveGetter()
set children: ƒ reactiveSetter(newVal)
get name: ƒ reactiveGetter()
set name: ƒ reactiveSetter(newVal)
get tic_add_date: ƒ reactiveGetter()
set tic_add_date: ƒ reactiveSetter(newVal)
get tic_id: ƒ reactiveGetter()
set tic_id: ƒ reactiveSetter(newVal)
get tic_name: ƒ reactiveGetter()
set tic_name: ƒ reactiveSetter(newVal)
get tic_parent_id: ƒ reactiveGetter()
set tic_parent_id: ƒ reactiveSetter(newVal)
get tic_user_id: ƒ reactiveGetter()
set tic_user_id: ƒ reactiveSetter(newVal)
__proto__: Object
6:
children: Array(3)
0:
bool: true
name: "ivan1"
tic_add_date: "2020-09-11 16:14:38"
tic_center: "11"
tic_id: 8
tic_name: "11"
tic_parent_id: 4
tic_user_id: 1
__ob__: Observer {value: {…}, dep: Dep, vmCount: 0}
get name: ƒ reactiveGetter()
set name: ƒ reactiveSetter(newVal)
get tic_add_date: ƒ reactiveGetter()
set tic_add_date: ƒ reactiveSetter(newVal)
get tic_center: ƒ reactiveGetter()
set tic_center: ƒ reactiveSetter(newVal)
get tic_id: ƒ reactiveGetter()
set tic_id: ƒ reactiveSetter(newVal)
get tic_name: ƒ reactiveGetter()
set tic_name: ƒ reactiveSetter(newVal)
get tic_parent_id: ƒ reactiveGetter()
set tic_parent_id: ƒ reactiveSetter(newVal)
get tic_user_id: ƒ reactiveGetter()
set tic_user_id: ƒ reactiveSetter(newVal)
__proto__: Object
1: {…}
2: {…}
length: 3
__ob__: Observer {value: Array(3), dep: Dep, vmCount: 0}
__proto__: Array
isbool: true
name: "ivan1"
tic_add_date: "2020-09-10 12:02:41"
tic_id: 4
tic_name: "test2"
tic_parent_id: 0
tic_user_id: 1
__ob__: Observer {value: {…}, dep: Dep, vmCount: 0}
get children: ƒ reactiveGetter()
set children: ƒ reactiveSetter(newVal)
get name: ƒ reactiveGetter()
set name: ƒ reactiveSetter(newVal)
get tic_add_date: ƒ reactiveGetter()
set tic_add_date: ƒ reactiveSetter(newVal)
get tic_id: ƒ reactiveGetter()
set tic_id: ƒ reactiveSetter(newVal)
get tic_name: ƒ reactiveGetter()
set tic_name: ƒ reactiveSetter(newVal)
get tic_parent_id: ƒ reactiveGetter()
set tic_parent_id: ƒ reactiveSetter(newVal)
get tic_user_id: ƒ reactiveGetter()
set tic_user_id: ƒ reactiveSetter(newVal)
__proto__: Object
7:
bool: true
name: "ivan1"
tic_add_date: "2020-09-11 16:14:38"
tic_center: "11"
tic_id: 8
tic_name: "11"
tic_parent_id: 4
tic_user_id: 1
__ob__: Observer {value: {…}, dep: Dep, vmCount: 0}
get name: ƒ reactiveGetter()
set name: ƒ reactiveSetter(newVal)
get tic_add_date: ƒ reactiveGetter()
set tic_add_date: ƒ reactiveSetter(newVal)
get tic_center: ƒ reactiveGetter()
set tic_center: ƒ reactiveSetter(newVal)
get tic_id: ƒ reactiveGetter()
set tic_id: ƒ reactiveSetter(newVal)
get tic_name: ƒ reactiveGetter()
set tic_name: ƒ reactiveSetter(newVal)
get tic_parent_id: ƒ reactiveGetter()
set tic_parent_id: ƒ reactiveSetter(newVal)
get tic_user_id: ƒ reactiveGetter()
set tic_user_id: ƒ reactiveSetter(newVal)
__proto__: Object
8:
bool: true
name: "ivan1"
tic_add_date: "2020-09-10 12:03:22"
tic_id: 6
tic_name: "2-222"
tic_parent_id: 4
tic_user_id: 1
__ob__: Observer {value: {…}, dep: Dep, vmCount: 0}
get name: ƒ reactiveGetter()
set name: ƒ reactiveSetter(newVal)
get tic_add_date: ƒ reactiveGetter()
set tic_add_date: ƒ reactiveSetter(newVal)
get tic_id: ƒ reactiveGetter()
set tic_id: ƒ reactiveSetter(newVal)
get tic_name: ƒ reactiveGetter()
set tic_name: ƒ reactiveSetter(newVal)
get tic_parent_id: ƒ reactiveGetter()
set tic_parent_id: ƒ reactiveSetter(newVal)
get tic_user_id: ƒ reactiveGetter()
set tic_user_id: ƒ reactiveSetter(newVal)
__proto__: Object
9:
bool: true
name: "ivan1"
tic_add_date: "2020-09-10 12:03:13"
tic_id: 5
tic_name: "2-111"
tic_parent_id: 4
tic_user_id: 1
__ob__: Observer {value: {…}, dep: Dep, vmCount: 0}
get name: ƒ reactiveGetter()
set name: ƒ reactiveSetter(newVal)
get tic_add_date: ƒ reactiveGetter()
set tic_add_date: ƒ reactiveSetter(newVal)
get tic_id: ƒ reactiveGetter()
set tic_id: ƒ reactiveSetter(newVal)
get tic_name: ƒ reactiveGetter()
set tic_name: ƒ reactiveSetter(newVal)
get tic_parent_id: ƒ reactiveGetter()
set tic_parent_id: ƒ reactiveSetter(newVal)
get tic_user_id: ƒ reactiveGetter()
set tic_user_id: ƒ reactiveSetter(newVal)
__proto__: Object
10:
children: Array(2)
0:
bool: true
name: "ivan1"
tic_add_date: "2020-09-10 12:02:29"
tic_id: 3
tic_name: "222"
tic_parent_id: 1
tic_user_id: 1
__ob__: Observer {value: {…}, dep: Dep, vmCount: 0}
get name: ƒ reactiveGetter()
set name: ƒ reactiveSetter(newVal)
get tic_add_date: ƒ reactiveGetter()
set tic_add_date: ƒ reactiveSetter(newVal)
get tic_id: ƒ reactiveGetter()
set tic_id: ƒ reactiveSetter(newVal)
get tic_name: ƒ reactiveGetter()
set tic_name: ƒ reactiveSetter(newVal)
get tic_parent_id: ƒ reactiveGetter()
set tic_parent_id: ƒ reactiveSetter(newVal)
get tic_user_id: ƒ reactiveGetter()
set tic_user_id: ƒ reactiveSetter(newVal)
__proto__: Object
1: {…}
length: 2
__ob__: Observer {value: Array(2), dep: Dep, vmCount: 0}
__proto__: Array
isbool: true
name: "ivan1"
tic_add_date: "2020-09-08 08:33:02"
tic_id: 1
tic_name: "test"
tic_parent_id: 0
tic_user_id: 1
__ob__: Observer {value: {…}, dep: Dep, vmCount: 0}
get children: ƒ reactiveGetter()
set children: ƒ reactiveSetter(newVal)
get name: ƒ reactiveGetter()
set name: ƒ reactiveSetter(newVal)
get tic_add_date: ƒ reactiveGetter()
set tic_add_date: ƒ reactiveSetter(newVal)
get tic_id: ƒ reactiveGetter()
set tic_id: ƒ reactiveSetter(newVal)
get tic_name: ƒ reactiveGetter()
set tic_name: ƒ reactiveSetter(newVal)
get tic_parent_id: ƒ reactiveGetter()
set tic_parent_id: ƒ reactiveSetter(newVal)
get tic_user_id: ƒ reactiveGetter()
set tic_user_id: ƒ reactiveSetter(newVal)
__proto__: Object
11:
bool: true
name: "ivan1"
tic_add_date: "2020-09-10 12:02:29"
tic_id: 3
tic_name: "222"
tic_parent_id: 1
tic_user_id: 1
__ob__: Observer {value: {…}, dep: Dep, vmCount: 0}
get name: ƒ reactiveGetter()
set name: ƒ reactiveSetter(newVal)
get tic_add_date: ƒ reactiveGetter()
set tic_add_date: ƒ reactiveSetter(newVal)
get tic_id: ƒ reactiveGetter()
set tic_id: ƒ reactiveSetter(newVal)
get tic_name: ƒ reactiveGetter()
set tic_name: ƒ reactiveSetter(newVal)
get tic_parent_id: ƒ reactiveGetter()
set tic_parent_id: ƒ reactiveSetter(newVal)
get tic_user_id: ƒ reactiveGetter()
set tic_user_id: ƒ reactiveSetter(newVal)
__proto__: Object
12:
bool: true
name: "ivan1"
tic_add_date: "2020-09-10 11:11:10"
tic_id: 2
tic_name: "111"
tic_parent_id: 1
tic_user_id: 1
__ob__: Observer {value: {…}, dep: Dep, vmCount: 0}
get name: ƒ reactiveGetter()
set name: ƒ reactiveSetter(newVal)
get tic_add_date: ƒ reactiveGetter()
set tic_add_date: ƒ reactiveSetter(newVal)
get tic_id: ƒ reactiveGetter()
set tic_id: ƒ reactiveSetter(newVal)
get tic_name: ƒ reactiveGetter()
set tic_name: ƒ reactiveSetter(newVal)
get tic_parent_id: ƒ reactiveGetter()
set tic_parent_id: ƒ reactiveSetter(newVal)
get tic_user_id: ƒ reactiveGetter()
set tic_user_id: ƒ reactiveSetter(newVal)
__proto__: Object
length: 13
__ob__: Observer {value: Array(13), dep: Dep, vmCount: 0}
__proto__: Array

 

 

posted @ 2020-09-15 10:19  鸣人卷~~  阅读(1234)  评论(0编辑  收藏  举报