当前位置:   article > 正文

ElementUI 树形表格的使用以及表单嵌套树形表格的校验问题等汇总_elementui 表格嵌套表格

elementui 表格嵌套表格

目录

一、树形表格如何添加序号体现层级关系 

二、树形表格展开收缩图标位置放置,设置指定列

三、表单嵌套树形表格的校验问题以及如何给校验rules传参

普通表格绑定如下:这种方法只能校验表格的第一层,树形需要递归设置子级节点prop。

树形表格绑定如下:使用下面的方法(复制粘贴可以直接用)

四、树形表格如何通过某属性值进行过滤展示

1、可使用:row-style="tableRowClassName"去进行筛选 控制显隐 这个方法比较简单且不改变原treedata数据

2、过滤满足属性值需要的节点生成新的treedata数据来渲染表格


一、树形表格如何添加序号体现层级关系 

实现:treeData为表格数据,递归调用getProjectIndex方法即可实现;例如:1,1,1,1.2

  1. <el-table-column label="序号" width="100" type="">
  2. <template slot-scope="scope">{{ scope.row.projectIndex }}</template>
  3. </el-table-column>
  4. // 添加索引
  5. addIndex() {
  6. this.treeData.forEach((node, i) => {
  7. this.getProjectIndex(node, '', i)
  8. // 默认展开第一层
  9. this.expandKeys.push(node.id + '')
  10. })
  11. },
  12. // 获取序号
  13. getProjectIndex(node, parentIndex, index) {
  14. const projectIndex = parentIndex ? `${parentIndex}.${index + 1}` : `${index + 1}`
  15. node.projectIndex = projectIndex
  16. if (node.children) {
  17. node.children.forEach((child, i) => {
  18. this.getProjectIndex(child, projectIndex, i)
  19. })
  20. }
  21. },

二、树形表格展开收缩图标位置放置,设置指定列

在不需要的列前加上   type=""

  1. <el-table-column label="序号" width="100" type="">
  2. <template slot-scope="scope">{{ scope.row.projectIndex }}</template>
  3. </el-table-column>

三、表单嵌套树形表格的校验问题以及如何给校验rules传参

需求:一个树形表格中每个树节点都需要有日期范围,想要校验子节点的日期范围不能超过父节点;

解决:如何绑定form的prop值?先了解如何绑定普通表格进行校验

  1. 普通表格绑定如下:这种方法只能校验表格的第一层,树形需要递归设置子级节点prop。
    1. <template slot-scope="scope">
    2. <el-form-item :prop="`treeData.${scope.$index}.beginDate`" :rules="beginDateRules">
    3. <el-date-picker
    4. v-model="scope.row.beginDate"
    5. type="date"
    6. clearable
    7. format="yyyy-MM-dd"
    8. value-format="yyyy-MM-dd"
    9. placeholder="开始日期"
    10. />
    11. </el-form-item>
    12. </template>
  2. 树形表格绑定如下:使用下面的方法(复制粘贴可以直接用)
  1. findPosi(tree, targetId, path = '') {
  2. for (let i = 0; i < tree.length; i++) {
  3. const node = tree[i]
  4. if (node.id === targetId) {
  5. return path + i
  6. }
  7. if (node.children && node.children.length > 0) {
  8. const childPath = `${path}${i}.children.`
  9. const result = this.findPosi(node.children, targetId, childPath)
  10. if (result !== null) {
  11. return result
  12. }
  13. }
  14. }
  15. return null
  16. }

具体代码实现如下:

  1. //1、表单表格嵌套实现代码 其余省略
  2. <el-form ref="treeForm" :model="treeForm">
  3. <el-table
  4. :data="treeForm.treeData"
  5. row-key="id"
  6. :row-style="tableRowClassName"
  7. :expand-row-keys="expandKeys"
  8. :tree-props="{ children: 'children'}"
  9. >
  10. <el-table-column label="预计周期" width="310" align="center">
  11. <template slot-scope="scope">
  12. <el-form-item
  13. :prop="'treeData.' + findPosi(treeForm.treeData,scope.row.id) + '.beginDate'"
  14. :rules="beginDateRules(scope.row)"
  15. >
  16. <el-date-picker
  17. v-model="scope.row.beginDate"
  18. :style="{width: '100%'}"
  19. type="date"
  20. clearable
  21. format="yyyy-MM-dd"
  22. value-format="yyyy-MM-dd"
  23. placeholder="开始日期"
  24. />
  25. </el-form-item>
  26. </template>
  27. </el-table-column>
  28. </el-table>
  29. </el-form>
  1. //2、script标签内容
  2. //定义的数据格式
  3. treeForm: {
  4. treeData: []
  5. },
  6. //方法调用 给rules传参方式
  7. beginDateRules(row) {
  8. return [
  9. { validator: (rule, value, callback) => { this.validateBeginDate(rule, value, callback, row) }, trigger: 'blur' }
  10. ]
  11. },
  12. validateBeginDate(rule, value, callback, row) {
  13. // 没有父节点不做判断
  14. if (row.parentId === 0) {
  15. callback()
  16. } else {
  17. // 查找父节点
  18. const node = findParentId(this.treeForm.treeData, row.parentId)
  19. if (value && node.beginDate !== null) {
  20. if (new Date(value) < new Date(node.beginDate)) {
  21. callback(new Error('不能超过上一阶段日期'))
  22. } else {
  23. callback()
  24. }
  25. } else {
  26. callback()
  27. }
  28. }
  29. },
  30. //用到的工具类
  31. // 1定义一个递归函数,接受一个对象或数组,一个目标id值和一个路径数组作为参数 查找目标id所在的路径
  32. findPosi(tree, targetId, path = '') {
  33. for (let i = 0; i < tree.length; i++) {
  34. const node = tree[i]
  35. if (node.id === targetId) {
  36. return path + i
  37. }
  38. if (node.children && node.children.length > 0) {
  39. const childPath = `${path}${i}.children.`
  40. const result = this.findPosi(node.children, targetId, childPath)
  41. if (result !== null) {
  42. return result
  43. }
  44. }
  45. }
  46. return null
  47. }
  48. //2通过节点id查找其父节点信息
  49. /**
  50. * @param {*} tree
  51. * @param {*} targetId
  52. * @param {*} parentId
  53. * @returns
  54. * 通过节点id查找其父节点信息
  55. */
  56. export function findParentId(tree, targetId) {
  57. for (const node of tree) {
  58. if (node.id === targetId) {
  59. return node
  60. }
  61. if (node.children) {
  62. const result = findParentId(node.children, targetId, node.id)
  63. if (result !== null) {
  64. return result
  65. }
  66. }
  67. }
  68. return null
  69. }

四、树形表格如何通过某属性值进行过滤展示

1、可使用:row-style="tableRowClassName"去进行筛选 控制显隐 这个方法比较简单且不改变原treedata数据
  1. tableRowClassName(data) {
  2.       if (data.row.enabled === '0') {
  3.         return { display: 'none' }
  4.       }
  5.     },
2、过滤满足属性值需要的节点生成新的treedata数据来渲染表格

原数据 treeData:[] 新数据:tree:[] 调用getenabledNodes()方法

  1. // 筛选选中节点
  2. getenabledNodes() {
  3. const tree = this.filterUnenabledNodes(this.treeData)
  4. console.log(tree)
  5. },
  6. filterUnenabledNodes(treeData) {
  7. const filteredData = []
  8. treeData.forEach(node => {
  9. if (node.enabled === '1') {
  10. filteredData.push(Object.assign({}, node, {
  11. children: node.children ? this.filterUnenabledNodes(node.children) : []
  12. }))
  13. }
  14. })
  15. return filteredData
  16. },
声明:本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:【wpsshop博客】
推荐阅读
相关标签
  

闽ICP备14008679号