el-tree树结合el-pagination分页查询展示

在开发过程中遇到需要将分页接口的数据展示在树形结构中的需求

一、效果

el-tree树结合el-pagination分页查询展示_第1张图片

二、实现

2.1后端接口

使用mock

// el-tree 数据接口 分页
import Mock from 'mockjs'

const count = 100

const items = [
    {
        "id": 1,
        "appId": "00d39caf58c34b2a2a1f1e442f525268",
        "appName": "D应用",
        "userId": "1",
        "dUserName": "d",
        "createdTime": "2021-01-08T02:55:30.000+0000",
        "createdBy": "admin",
        "modifyBy": "admin",
        "modifyTime": "2021-01-11T07:31:30.000+0000"
      },
      {
        "id": 2,
        "appId": "018eae54ebcd78bbc22ef6aec213743f",
        "appName": "D应用",
        "userId": "1",
        "dUserName": "dcoos",
        "createdTime": "2021-01-08T02:55:30.000+0000",
        "createdBy": "admin",
        "modifyBy": "admin",
        "modifyTime": "2021-01-08T02:55:30.000+0000"
      },
      {
        "id": 3,
        "appId": "02030acd4bc549e866cc33d1d1b2d62b",
        "appName": "D应用",
        "userId": "1",
        "dUserName": "dcoos",
        "createdTime": "2021-01-08T02:55:30.000+0000",
        "createdBy": "admin",
        "modifyBy": "admin",
        "modifyTime": "2021-01-08T02:55:30.000+0000"
      }
];


export default [
    {
        url: '/tree/data',
        type: 'get',
        response: config => {
            const {page , limit = 10 } = config.query
            
            const pageList = items.filter((item,index) => index < limit * page && index >= limit * (page - 1))

            return {
                code: 20000,
                data: {
                    total: items.length,
                    items: pageList
                },
                msg: '查询成功',
                traceId: '798215010391162880',
                success: true
            }
        }

    }
]

2.2 api接口

import request from '@/utils/request'

export function getTreeData(param) {
    let config = {
        params: param
    }
    return request({
        url: '/tree/data',
        method: 'get',
        ...config
    })
}

2.3 vue页面实现

<template>
   <div>
        <el-tree
                class="filter-tree"
                :data="appData"
                node-key="id"
                :props="defaultProps"
                ref="tree"
                @node-click="handleNodeClick"
        >
            <span class="custom-tree-node" slot-scope="{ node, data }">
                <span>
                        <i v-if="data.items&&data.items.length>0" class="el-icon-folder-add" style="padding-right:5px;color: #c0c4cc"/>
                    <i v-else /><span :title="node.label">{{ node.label }}</span>
                </span>
            </span>
        </el-tree>

        <!-- 分页栏 -->
        <div class="bottom">
            <el-pagination background small :pager-count="5" @size-change="handleSizeChange" @current-change="handleCurrentChange"
                            :current-page.sync="appUserRel.page" :page-size="appUserRel.limit"
                            layout="prev, pager, next" :total="appUserRel.total"></el-pagination>
        </div>
    </div>
</template>

<script>
import { getTreeData } from '@/api/tree'

export default {
    name: 'index',
    data() {
        return {
            appData: [],
            // 配置选项: children-指定子树为节点对象的某个属性值; label-指定节点标签为节点对象的某个属性值;
            defaultProps: {
                children: 'items',
                label: 'appId'
            },
            appUserRelList: [],
            appUserRel: {
                limit: 10,
                total: 130,
                page: 1
            }
        }
    },
    created() {
        let param = {
                page: 1,
                limit: 10
            }
        this.queryTreeData(param)
    },
    methods: {
        queryTreeData(param) {
            getTreeData(param).then(response => {
                // console.log(response)
                let res = response.data
                let appData = []
                let appUserRelList = res.items
                if (appUserRelList.length!==0) {
                    appData = [
                        {appId: '所有APP', items: appUserRelList}
                    ]
                }
                this.appData = appData
                this.appUserRelList = appUserRelList
                this.appUserRel.total = res.total
            })
        },
        handleNodeClick(data) {
                this.appSelection = []
                if(data){
                    // this.appSelection.push(data.name)
                    // 根节点不查询
                    console.log(data.appId)
                    if (data.appId==="所有APP") {
                        return
                    }
                    console.log(data.appId)
                }
        },
        // 当每页数量改变
        handleSizeChange(val) {
            this.appUserRel.limit = val
        },
        handleCurrentChange(val) {
            console.log(`当前页: ${val}`);
            this.appUserRel.page = val
            let param = {
                limit: 10,
                page: val
            }
            this.queryTreeData(param)
        }
    }
}
</script>

<style>
</style>

你可能感兴趣的:(学习,vue,javascript)