设为首页收藏本站

安徽论坛

 找回密码
 立即注册

QQ登录

只需一步,快速开始

查看: 12980|回复: 0

Vue elementUI实现树形结构表格与懒加载

[复制链接]

63

主题

499

回帖

947

积分

高级会员

Rank: 4

积分
947
发表于 2022-3-26 11:01:42 | 显示全部楼层 |阅读模式
网站内容均来自网络,本站只提供信息平台,如有侵权请联系删除,谢谢!
目录


1、实现效果



2、后端实现


2.1 实体类
  1. @Data
  2. @ApiModel(description = "数据字典")
  3. @TableName("dict")
  4. public class Dict {

  5.     private static final long serialVersionUID = 1L;

  6.     @ApiModelProperty(value = "id")
  7.     private Long id;

  8.     @ApiModelProperty(value = "创建时间")
  9.     @JsonFormat(pattern = "yyyy-MM-dd HH:mm:ss")
  10.     @TableField("create_time")
  11.     private Date createTime;

  12.     @ApiModelProperty(value = "更新时间")
  13.     @TableField("update_time")
  14.     private Date updateTime;

  15.     @ApiModelProperty(value = "逻辑删除(1:已删除,0:未删除)")
  16.     @TableLogic
  17.     @TableField("is_deleted")
  18.     private Integer isDeleted;

  19.     @ApiModelProperty(value = "其他参数")
  20.     @TableField(exist = false)
  21.     private Map<String,Object> param = new HashMap<>();

  22.     @ApiModelProperty(value = "上级id")
  23.     @TableField("parent_id")
  24.     private Long parentId;

  25.     @ApiModelProperty(value = "名称")
  26.     @TableField("name")
  27.     private String name;

  28.     @ApiModelProperty(value = "值")
  29.     @TableField("value")
  30.     private String value;

  31.     @ApiModelProperty(value = "编码")
  32.     @TableField("dict_code")
  33.     private String dictCode;

  34.     @ApiModelProperty(value = "是否包含子节点")
  35.     @TableField(exist = false)
  36.     private boolean hasChildren;

  37. }
复制代码
上面必须包含一个hasChildren属性,即使数据库中没有该属性,这是element框架要求的。

2.2 数据库中的数据结构



2.3 后端接口

如果完全用后端实现的话,那写个递归把所有数据按照层次结构查询完并封装好即可。但element的table组件给我们封装好了一些东西,我们只需要在这里根据上级id查询子数据列表即可。
controller代码:
  1. //根据上级id查询子数据列表
  2.     @ApiOperation(value = "根据上级id查询子数据列表")
  3.     @GetMapping("findChildData/{id}")
  4.     public Result findChildData(@PathVariable Long id){
  5.         List<Dict> list = dictService.findChildData(id);
  6.         return Result.ok(list);
  7.     }
复制代码
service

service实现类
  1. @Service
  2. public class DictServiceImpl extends ServiceImpl<DictMapper, Dict> implements DictService {

  3.     //根据上级id查询子数据列表
  4.     @Override
  5.     public List<Dict> findChildData(Long id) {
  6.         QueryWrapper<Dict> wrapper=new QueryWrapper<>();
  7.         wrapper.eq("parent_id",id);
  8.         List<Dict> list = baseMapper.selectList(wrapper);
  9.         //向list集合中的每个dict对象中设置hasChildren
  10.         list.forEach(x->{
  11.             Long dictId = x.getId();
  12.             boolean isChild = this.isChildren(dictId);
  13.             x.setHasChildren(isChild);
  14.         });
  15.         return list;
  16.     }

  17.     //判断id下面是否有子数据
  18.     private boolean isChildren(Long id){
  19.         QueryWrapper<Dict> wrapper=new QueryWrapper<>();
  20.         wrapper.eq("parent_id",id);
  21.         Integer count = baseMapper.selectCount(wrapper);
  22.         return count > 0;
  23.     }
  24. }
复制代码
2.4 swagger测试后端结构功能是否正常



3、前端实现


3.1 页面中引入el-table组件

list.vue
  1. <template>
  2.   <div class="app-container">

  3.     <el-table
  4.       :data="list"
  5.       style="width: 100%"
  6.       row-key="id"
  7.       border
  8.       lazy
  9.       :load="getChildrens"
  10.       :tree-props="{children: 'children', hasChildren: 'hasChildren'}">
  11.       <el-table-column label="名称" width="230" align="left">
  12.         <template slot-scope="scope">
  13.           <span>{{ scope.row.name }}</span>
  14.         </template>
  15.       </el-table-column>

  16.       <el-table-column label="编码" width="220">
  17.         <template slot-scope="{row}">
  18.           {{ row.dictCode }}
  19.         </template>
  20.       </el-table-column>
  21.       <el-table-column label="值" width="230" align="left">
  22.         <template slot-scope="scope">
  23.           <span>{{ scope.row.value }}</span>
  24.         </template>
  25.       </el-table-column>
  26.       <el-table-column label="创建时间" align="center">
  27.         <template slot-scope="scope">
  28.           <span>{{ scope.row.createTime }}</span>
  29.         </template>
  30.       </el-table-column>
  31.     </el-table>
  32.   </div>

  33. </template>

  34. <script>
  35. import dict from '@/api/dict'
  36. export default {
  37.   name: 'list',
  38.   data(){
  39.     return{
  40.       list:[], //数据字典列表数组
  41.       dialogImportVisible:false,  //设置弹框是否弹出
  42.     }
  43.   },
  44.   created() {
  45.     this.getDictList(1)
  46.   },
  47.   methods:{
  48.     //数据字典列表
  49.     getDictList(id){
  50.       dict.dictList(id)
  51.         .then(response=>{
  52.             this.list=response.data
  53.         })
  54.     },
  55.     getChildrens(tree, treeNode, resolve) {
  56.       dict.dictList(tree.id).then(response => {
  57.         resolve(response.data)
  58.       })
  59.     },
  60.   }
  61. }
  62. </script>

  63. <style scoped>

  64. </style>
复制代码
上面关键的方法是getChildrens这个方法,在每一层调用后端接口将子节点数据查询出来,并加入树形结构的表格数据中。
调用后端结构的工具js文件 dict.js
  1. import request from '@/utils/request'

  2. export default {
  3.   //数据字典列表
  4.   dictList(id){
  5.     return request({
  6.       url: `/admin/cmn/dict/findChildData/${id}`,
  7.       method: 'get'
  8.     })
  9.   },
  10. }
复制代码
3.2 实现效果


前后端测试都没有问题,由于使用的是懒加载,只有去点击父节点的时候,子节点的数据才会被加载,避免因数据量太大导致系统卡顿。
到此这篇关于Vue elementUI实现树形结构表格与懒加载的文章就介绍到这了,更多相关Vue elementUI内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!
                                                        
免责声明:如果侵犯了您的权益,请联系站长,我们会及时删除侵权内容,谢谢合作!

本帖子中包含更多资源

您需要 登录 才可以下载或查看,没有账号?立即注册

x
免责声明
1. 本论坛所提供的信息均来自网络,本网站只提供平台服务,所有账号发表的言论与本网站无关。
2. 其他单位或个人在使用、转载或引用本文时,必须事先获得该帖子作者和本人的同意。
3. 本帖部分内容转载自其他媒体,但并不代表本人赞同其观点和对其真实性负责。
4. 如有侵权,请立即联系,本网站将及时删除相关内容。
懒得打字嘛,点击右侧快捷回复 【右侧内容,后台自定义】
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

快速回复 返回顶部 返回列表