通过点击el-table内的某个值触发el-tree的click

在这里插入图片描述

<!DOCTYPE html>
<html lang="en">
  <head>
    <meta charset="UTF-8" />
    <meta name="viewport" content="width=device-width, initial-scale=1.0" />
    <title>Document</title>
    <link
      rel="stylesheet"
      href="https://unpkg.com/element-ui/lib/theme-chalk/index.css"
    />
    <script src="https://cdn.jsdelivr.net/npm/vue@2/dist/vue.js"></script>
    <!-- 引入组件库 -->
    <script src="https://unpkg.com/element-ui/lib/index.js"></script>
  </head>
  <body>
    <div id="app">
      <div style="display: flex">
        <div style="width: 200px; padding: 20px">
          <!-- 开启手风琴 -->
          <!-- accordion -->
          <el-tree
            :data="data"
            :props="defaultProps"
            @node-click="handleNodeClick"
            node-key="id"
            :default-expanded-keys="defaultExpandedId"
            ref="selfTree"
          ></el-tree>
        </div>

        <el-table :data="tableData" style="flex: 1">
          <el-table-column prop="date" label="日期" min-width="180">
          </el-table-column>
          <el-table-column prop="name" label="姓名" min-width="180">
          </el-table-column>
          <el-table-column prop="label" label="地址" min-width="580">
            <template #default="{row}">
              <div @click.stop="showTreeChange(row.label)">{{row.label}}</div>
            </template>
          </el-table-column>
        </el-table>
      </div>
    </div>

    <script>
      new Vue({
        el: '#app',
        data() {
          return {
            defaultExpandedId: [],
            tableData: [
              {
                date: '2016-05-02',
                name: '王小虎',
                label: '三级 1-1-1',
              },
              {
                date: '2016-05-04',
                name: '王小虎',
                label: '二级 2-1',
              },
            ],
            data: [
              {
                id: 1,
                label: '一级 1',
                children: [
                  {
                    id: 4,
                    label: '二级 1-1',
                    children: [
                      {
                        id: 9,
                        label: '三级 1-1-1',
                      },
                      {
                        id: 10,
                        label: '三级 1-1-2',
                      },
                    ],
                  },
                ],
              },
              {
                id: 2,
                label: '一级 2',
                children: [
                  {
                    id: 5,
                    label: '二级 2-1',
                  },
                  {
                    id: 6,
                    label: '二级 2-2',
                  },
                ],
              },
            ],
            defaultProps: {
              children: 'children',
              label: 'label',
            },
          };
        },
        methods: {
          showTreeChange(e) {
            let item = this.getIds(this.data, e);
            if (Object.keys(item).length != 0) {
              // 开启手风琴
              // var nodes = this.$refs.selfTree.store.nodesMap;
              // for (var i in nodes) {
              //   nodes[i].expanded = false;
              // }
              // 展开tree节点
              this.defaultExpandedId = [item.id];
              // 获取点击的tree节点
              let node = this.$refs.selfTree.getNode(item);
              // 触发tree点击事件
              this.handleNodeClick(item, node);
            }
          },
          getIds(arr, name) {
            let result = {};
            arr.forEach((item) => {
              if (item.label == name) {
                Object.assign(result, item);
              }
              if (item.children && item.children.length > 0) {
                Object.assign(result, this.getIds(item.children, name));
              }
            });
            return result;
          },
          handleNodeClick(e, node) {
            console.log(e, node, '执行tree的点击事件');
          },
        },
      });
    </script>
  </body>
</html>
  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
引用和提到了ElementUI中el-tree节点的操作实现。el-tree是一个树状结构组件,可以用于展示层级数据。结合el-table使用,可以实现点击节点加载该节点下的学生数据。 具体实现可以分为以下几个步骤: 1. 首先,需要在el-tree中设置节点点击事件。当某个节点点击时,触发事件并获取该节点的信息。 2. 在点击事件中,根据节点的信息,可以进行数据请求,加载该节点下的学生数据。可以通过分页的方式进行数据加载,如引用中提到的根据节点进行分页。 3. 加载学生数据后,可以将数据传递给el-table进行渲染。可以使用el-table的data属性绑定学生数据,同时根据需要设置相关的列和样式。 4. 另外,在关闭弹窗组件时,可以将选择的学生数据进行备份,以便下次打开弹窗时能够加载并渲染这些数据。可以使用window.localStorage将选择的学生数据存储起来,并在需要时进行获取和清除操作,如引用中所示。 综上所述,结合el-table使用el-tree可以实现点击节点加载该节点下的学生数据,并通过el-table进行渲染。具体的实现可以参考ElementUI的文档和示例代码。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* *3* [el-tree结合el-table的选择器](https://blog.csdn.net/RuofeiX/article/details/118154329)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_1"}}] [.reference_item style="max-width: 50%"] - *2* [ElementUI中el-tree节点的操作的实现](https://download.csdn.net/download/weixin_38607026/12927696)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_1"}}] [.reference_item style="max-width: 50%"] [ .reference_list ]

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值