我看过几乎所有关于如何使用角度材质树复选框组件的示例。例如官方示例和this.
这些示例向我们展示了字符串数组结构作为数据的绑定。但是我们如何将嵌套的复杂对象数组转换为这个组件呢?
我的数据结构:
如您所见,数据告诉客户必须将复选框的哪些项目设置为勾选。并且'Id'必须绑定到树上。
当我用官方示例“TREE-DATA”替换我的“TREE-DATA”时,我看到以下树作为结果。
我想我们需要在官方示例中更改“buildFileTree()”或“transformer()”方法。
Angular(7.0.0), Angular Material(6.4.7)
最后我解决了这个问题,我在这个地方写了一个示例
问题是如何解决的?
我对“buildFileTree()”和“transformer()”方法做了一些更改。您可以在以下代码中看到更改:
buildFileTree(obj: {[key: string]: any}, level: number): TodoItemNode[] {
return Object.keys(obj).reduce<TodoItemNode[]>((accumulator, key) => {
const item = obj[key];
const node = new TodoItemNode();
node.label = obj[key].name;
node.id = obj[key].id;
node.isChecked= obj[key].isChecked;
node.claimId= obj[key].claimId;
node.isPlanType= obj[key].isPlanType;
if (item != null) {
if (typeof item === 'object' && item.children!= undefined) {
node.children = this.buildFileTree(item.children, level + 1);
} else {
node.label = item.name;
}
}
return accumulator.concat(node);
}, []);}
transformer = (node: TodoItemNode, level: number) => {
const existingNode = this.nestedNodeMap.get(node);
const flatNode = existingNode && existingNode.label === node.label
? existingNode
: new TodoItemFlatNode();
flatNode.label = node.label;
flatNode.level = level;
flatNode.id=node.id;
flatNode.isChecked = node.isChecked;
flatNode.claimId = node.claimId;
flatNode.isPlanType = node.isPlanType;
flatNode.expandable = !!node.children;
this.flatNodeMap.set(flatNode, node);
this.nestedNodeMap.set(node, flatNode);
return flatNode; }