elementUI中的table的数据实现全部展开和收起功能

本文介绍如何使用elementUI的table组件,通过row-key属性和toggleRowExpansion方法来实现数据的全部展开和收起功能。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

elementUI中的table的数据实现全部展开和收起功能

用row-key这个属性和toggleRowExpansion这个方法即可实现

在这里插入图片描述
在这里插入图片描述

<template>
<el-table :data="tableData" row-key="id" class="table" ref="table">
          <el-table-column prop="resourceName" label="资源名称" align="center">
          </el-table-column>
          <el-table-column prop="resourceType" label="资源类型" align="center">
          </el-table-column>
          <el-table-column prop="order" label="显示顺序" align="center">
          </el-table-column>
          <el-table-column label="状态" align="center">
            <template slot-scope="scope">
              <span :class="scope.row.status ? 'typeActive' : ''">{{
                scope.row.status ? "启用中" : "已停用"
              }}</span>
            </template>
          </el-table-column>
          <el-table-column label="操作" align="center">
            <template slot-scope="scope">
              <el-button
                @click="addResource(scope.row)"
                type="text"
                size="small"
                >新增</el-button
              >
              <el-button
                @click="updateHandle(scope.row)"
                type="text"
                size="small"
                >修改</el-button
              >
              <el-button
                type="text"
                size="small"
                @click="deleteHandle(scope.row)"
                >删除</el-button
              >
              <el-button type="text" size="small" @click="blockUp(scope.row)">{{
                scope.row.enabledFlag ? "停用" : "启用"
              }}</el-button>
            </template>
          </el-table-column>
        </el-table>
</template>
<script>
 export default {
   data(){
    return {
     tableData:[]//表格数据
  }
},
methods:{
// 遍历表格数据
    forTableData(arr,isExpand){
        arr.forEach(i =>{
            this.$refs.table.toggleRowExpansion(i,isExpand);
            if(i.children){
                this.forTableData(i.children,isExpand)
            }
        })
    },
    //展开
    expand() {
        this.forTableData(this.tableData,true)
    },
    // 收起
    packUp() {
        this.forTableData(this.tableData,false)
    },
}
}
</script>
### ElementUI展开收起图标的自定义样式使用方法 在 ElementUI 的组件中,可以通过多种方式实现对树形结构、表格或其他可折叠组件的展开/收起图标进行自定义。以下是几种常见的场景及其解决方案。 #### 1. **Tree 组件的展开/收起图标** 对于 `el-tree` 组件,可以利用插槽功能来自定义节点前的图标。通过判断当前节点的状态(是否已展开),动态加载不同的图片或字体图标[^2]。 ```vue <el-tree :data="treeData" node-key="id"> <template #default="{ node, data }"> <span class="custom-tree-node"> <!-- 动态显示不同状态下的图标 --> <i v-if="!node.expanded" class="iconfont icon-list-collapse"></i> <i v-if="node.expanded" class="iconfont icon-shousuo"></i> <span style="margin-left: 8px;">{{ node.label }}</span> </span> </template> </el-tree> ``` 此代码片段展示了如何根据节点的扩展状态来切换图标类名,从而达到视觉上的变化效果。 --- #### 2. **Table 组件中的展开/收起操作** 针对带有嵌套数据展示需求的表格 (`el-table`),可通过事件监听器手动控制每一行的展开行为,并同步更新对应的图标状态[^1]。 ```javascript handleIconToggle(row) { this.$refs.topicTable.toggleRowExpansion(row); const currentIconRef = this.$refs[`myicon${row.id}`]; if (currentIconRef.getAttribute('class') === 'iconfont icon-list-collapse') { currentIconRef.setAttribute('class', 'iconfont icon-shousuo'); } else { currentIconRef.setAttribute('class', 'iconfont icon-list-collapse'); } } ``` 配合 HTML 部分: ```html <el-table ref="topicTable" :data="tableData"> <el-table-column type="expand"> <template slot-scope="scope"> <div>这里是隐藏的内容...</div> </template> </el-table-column> <el-table-column label="名称" prop="name"> <template slot-scope="scope"> <i ref="myicon{{ scope.row.id }}" class="iconfont icon-list-collapse"></i> {{ scope.row.name }} </template> </el-table-column> </el-table> ``` 这种方法允许开发者完全掌控何时改变特定 DOM 元素的属性值,灵活性较高。 --- #### 3. **Collapse 折叠面板的箭头方向调整** 如果目标是对 `el-collapse` 这样的折叠面板做进一步美化,则推荐借助 CSS 来修改默认样式的呈现形式[^3]。 ```css /* 修改未激活状态下箭头的文字 */ .v-deep .el-collapse-item__arrow:before { content: "展开"; font-size: 15px; font-family: 'heiti'; color: #2295ff; font-weight: bold; } /* 当处于活动状态时更换提示词 */ .v-deep .el-collapse-item__arrow.is-active::before { content: "收起"; font-size: 15px; font-family: 'heiti'; color: #2295ff; font-weight: 600; } /* 移除旋转动画 */ .v-deep .el-collapse-item__arrow.is-active { transform: none !important; } ``` 以上样式规则能够有效覆盖原始设计,使得用户体验更加直观友好。 --- ### 总结 无论是 Tree 表格还是 Collapse 面板,在实际开发过程中都可以依据业务逻辑灵活定制其交互细节。具体实现路径取决于所使用的 UI 库版本以及项目的技术栈约束条件。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值