el-table 动态添加children
时间: 2023-11-07 18:05:48 浏览: 178
根据你提供的引用内容,要在el-table中动态添加children节点,你可以使用this.$set方法来强制更新table的数据。具体的方法如下:
```
methods: {
addChildNode(row) {
let child = {
id: "",
name: "",
description: "",
children: []
};
if (row.children) {
this.$nextTick(() => {
row.children.push(child);
});
} else {
this.$nextTick(() => {
this.$set(row, "children", []);
row.children.push(child);
});
}
}
}
```
在addChildNode方法中,首先判断当前行是否已经有children属性,如果有,则直接将子节点添加到children数组中;如果没有,则先使用this.$set方法将children属性添加到当前行对象中,然后再将子节点添加到children数组中。这样就能保证表格的响应式更新。
相关问题
<el-table :data="tableData" :row-key="rowKey" border :tree-props="{children: 'children'}" :cell-class-name="dianClass" @cell-click="seeDetail" :header-cell-style="{background:'#f0f0f0'}"> <el-table-column width="50"></el-table-column> <el-table-column align="center" type="index" label="序号"> <template slot-scope="scope">{{ scope.$index + 1 }}</template> </el-table-column> <el-table-column align="center" prop="name" label="工程名称"></el-table-column> <el-table-column align="center" prop="code" label="工程编码"></el-table-column> <el-table-column align="center" prop="startDate" label="实际开工时间" :formatter="TimeFor"></el-table-column> <el-table-column align="center" prop="su" label="执行中的风险作业(A/B票)"></el-table-column> <el-table-column align="center" prop="ballNumber" label="布控球台数"></el-table-column> <el-table-column align="center" prop="toa" label="工程进度"></el-table-column> </el-table>
蓝色'}">这段代码的作用是什么?
这段代码是用来渲染一个表格的,其中包括以下几个属性:
- data:表格的数据源,即要展示的数据。
- row-key:表格行的唯一标识符,用于优化表格的渲染性能。
- border:是否显示表格的边框。
- tree-props:用于渲染树形表格,指定树形结构的子节点属性名为'children'。
- cell-class-name:用于自定义单元格的类名,可以根据数据的不同来动态添加类名。
- cell-click:单元格点击事件,可以在点击单元格时执行相应的操作。
- header-cell-style:表头单元格的样式,可以自定义表头单元格的样式,如背景色等。
<el-table :data="dialogObj.children"> <el-table-column prop="name" label="分项"></el-table-column> <el-table-column label="操作"> <template slot-scope="scope"> <el-button @click="deleteSelectedData(scope.$index)">删除</el-button> </template> </el-table-column> </el-table>设置一个滚轮
你可以将 `<el-table>` 组件包裹在一个固定高度的容器中,并设置 `overflow-y: scroll` 来实现滚动条的效果。例如:
```html
<div style="height: 300px; overflow-y: scroll;">
<el-table :data="dialogObj.children">
<el-table-column prop="name" label="分项"></el-table-column>
<el-table-column label="操作">
<template slot-scope="scope">
<el-button @click="deleteSelectedData(scope.$index)">删除</el-button>
</template>
</el-table-column>
</el-table>
</div>
```
这样,当表格内容超出容器高度时,会自动出现纵向滚动条。你可以根据需要调整容器的高度和样式。
阅读全文