前往官网查看:Vue Data Grid: Tree Data
使用树形数据来显示具有父/子关系的数据,其中的父/子关系是作为数据的一部分提供的。例如,一个文件夹可以包含零个或多个文件和其他文件夹。
在介绍更高级的用例之前,本节介绍使用树数据的简单方法。
为了将网格设置为与树数据一起使用,只需使用以下命令通过网格选项启用树数据模式:
<ag-grid-vue
:treeData="treeData"
/* other grid options ... */>
</ag-grid-vue>
this.treeData = true;
当向网格提供树状数据时,你要实现gridOptions.getDataPath(data)
回调,告诉网格每一行的层次结构。回调会返回一个string[]
,每个元素都指定了树的一个层次。下面是两个以不同方式呈现层次结构的例子。
getDataPath
: GetDataPath
getDataPath: GetDataPath<TData>;
interface GetDataPath<TData = any> {
(data: TData) : string[]
}
// 层次结构示例,Malcolm 是孩子或 Erica
// + Erica
// - Malcolm
// ############
// Example #1 - 数据中的层次结构已经是一个字符串数组
// ############
const rowData = [
{ orgHierarchy: ['Erica'], jobTitle: "CEO", employmentType: "Permanent" },
{ orgHierarchy: ['Erica', 'Malcolm'], jobTitle: "VP", employmentType: "Permanent" }
...
]
// 只需返回层次结构,不需要转换
getDataPath: data => {
return data.orgHierarchy;
}
// ############
// Example #2 - 层次结构是一个路径字符串,需要转换
// ############
const rowData = [
{ path: "Erica", jobTitle: "CEO", employmentType: "Permanent" },
{ path: "Erica/Malcolm", jobTitle: "VP", employmentType: "Permanent" }
...
]
// 回调将例如 "Erica/Malcolm"转换为["Erica", "Malcolm"]
getDataPath: data => {
return data.path.split('/'); // path: "Erica/Malcolm"
}
有两种配置组列的方法:
当网格使用树数据时,不需要明确指定组列,因为网格将使用自动组列(Auto Group Column)。 但是,您可能想要覆盖一些默认值,如下所示:
<ag-grid-vue
:autoGroupColumnDef="autoGroupColumnDef"
/* other grid options ... */>
</ag-grid-vue>
this.autoGroupColumnDef = {
headerName: "My Group",
width: 300,
cellRendererParams: {
suppressCount: true // 是否禁用标题行菜单
}
};
如上所述,提供您自己的自定义列组的优点是可以让您完全控制列组的显示,但是它不如使用默认的自动列组方便。
一个显著的区别是,整个dataPath
数组将作为一个值被提供,而不仅仅是当前节点的值。
更多细节见自定义组列(Custom Group Columns)
对于树形数据,不可能像对行分组那样有多个组的显示列。当做树状数据时,你应该只有一列来显示组。
下面的例子结合了上述所有步骤,展示了一个简化的组织层次结构。
前往查看示例:Org Hierarchy
如果组级别不需要数据,则不必在路径中包含每个级别的条目,如下所示:
// 提供的所有路径级别
const rowData = [
{ filePath: ['Documents'] },
{ filePath: ['Documents', 'txt'] },
{ filePath: ['Documents', 'txt', 'notes.txt'], dateModified: "21 May 2017, 13:50", size: "14 KB" }
...
]
// 只提供叶子级别
const rowData = [
{ filePath: ['Documents', 'txt', 'notes.txt'], dateModified: "21 May 2017, 13:50", size: "14 KB" }
...
]
上面的第二个变量省略了’Documents’和’txt’节点的行数据条目,在这种情况下,网格将为这些节点创建填充组。
下面这个例子包含列Group Type,以突出哪些节点是在行数据中提供的,哪些是由网格填充生成的。
前往查看示例:Filler Nodes
由于
Filler Groups
是由网格生成的,因此它们不会包含RowNode
上的数据属性。 如果你想为每个组提供一个id,即使在组级别没有显示数据时,或者如果你需要过滤/排序填充节点,这可能会有所限制。 为了过滤/排序可用,请提供所有节点作为数据集中的真实节点,而不是使用填充节点。
当使用树形数据时,用聚合函数定义的列将总是对组节点进行聚合。这意味着任何提供的组数据将被忽略,而支持聚合的值。
但是,如果没有子节点可以聚合,它将默认为行数据中提供的值。
下面的文件浏览器例子展示了对size列的聚合。
此外,你还可以参考聚合( Aggregation)部分的更多细节。
由于树状数据具有父/子关系,默认情况下,当父节点通过过滤器时,所有的子节点都会被包括在内,由于过滤是在所有组的层面上进行的,因此在以下情况下将包含一个组:
要覆盖这一行为以使用常规过滤,请启用以下网格选项属性:
<ag-grid-vue
:excludeChildrenWhenTreeDataFiltering="true"
/* other grid options ... */>
</ag-grid-vue>
另外请要注意,设置过滤器(Set Filter)将包含组层次结构中每一级的所有唯一值的列表。下面的文件浏览器例子演示了设置过滤器如何与树形数据一起工作。
以下示例提供了一个更复杂的示例,其中包括聚合和过滤:
前往查看示例:File Browser
在使用树状数据时,不可能进行透视或行分组。这意味着所有与透视(如colDef.pivot,或工具面板中的透视)和行分组(如colDef.rowGroup,或工具面板中的行分组)相关的功能将被禁用。
如果您要显示组的子计数,那么子计数就是所有子和孙子的计数。这与行分组(Row Grouping)不同,行分组只计算叶子层,在树状数据中,所有组的孩子也被计算在内。
要启用选择功能,请将gridOptions.rowSelection
设置为"single"
单选或"multiple"
多选,和平常一样。但是有一些限制需要注意。
树数据支持单击选择。 但是,当您显示树数据时,单击行进行选择会造成混淆,因为鼠标单击也用于扩展/收缩行。 出于这个原因,我们建议不要使用单击选择,而是使用复选框选择。
<ag-grid-vue
:suppressRowClickSelection="suppressRowClickSelection"
:autoGroupColumnDef="autoGroupColumnDef"
/* other grid options ... */>
</ag-grid-vue>
// 设置为true: 禁用单击时选择行
this.suppressRowClickSelection = true;
// 在组列上使用复选框
this.autoGroupColumnDef = {
cellRendererParams: {
checkbox: true,
}
};
如果填充组被移动,填充组不会保持其选择状态。例如,如果你有A->B->C组,其中C是唯一提供的行(所以网格为你创建了A和B组),然后你把补丁改为D->B->C,B组将不会保持它的选择。
下面是一个演示属性groupSelectsChildren
与树数据一起使用的例子。
在下面的示例中,请注意以下事项:
前往查看示例:Group Selects Children
如果聚合和过滤器在树状数据中被激活,有一件事需要关注。那就是聚合值会随着过滤器的应用而改变,这反过来会影响过滤器的结果。
当不使用树状数据过滤时,这不是一个问题,因为在正常的行分组(Row Grouping)中,组的行(聚集的地方)不被过滤,只有叶子的行被过滤。
但是对于树形数据来说,所有的行都会被过滤,因为所有的行都是组(叶子行只是一个没有孩子的组)。由于这个原因,如果你对一个有聚合功能的列进行过滤,在应用过滤器时,聚合值将是一个移动的目标。
要阻止聚合成为一个移动的目标,你需要设置网格属性suppressAggFilteredOnly=true
。这在聚合一节中有解释。