Accordion手风琴
可以折叠/展开的内容区域。
规则
- 对复杂区域进行分组和隐藏。
- 通常,一次只允许单个内容区域展开;特殊情况,多个内容区域可以同时展开。
代码演示
基本用法
最简单的用法。
import { Component, ViewChild, AfterViewInit, OnInit } from '@angular/core';
@Component({
selector: 'demo-accordion-basic',
template: `
<Accordion [defaultActiveKey]="'0'" [activeKey]="activeKey" (onChange)="onChange($event)">
<AccordionPanel
*ngFor="let item of accordions; let i = index"
[key]="i"
[header]="item.title"
[disabled]="item.inactive"
>
<List className="my-list">
<ListItem *ngFor="let content of item.child">
{{ content }}
</ListItem>
</List>
</AccordionPanel>
</Accordion>
<ng-template #title1>
<div>Title 1</div>
</ng-template>
<ng-template #title2>
<img src="/assets/img/logo.svg" style="width:36px"/>
</ng-template>
`
})
export class DemoAccordionBasicComponent implements OnInit {
@ViewChild('title1', { static: true }) title1: ViewChild;
@ViewChild('title2', { static: true }) title2: ViewChild;
accordions: Array<any> = [];
activeKey = [0, 1];
onChange(event) {
console.log(event);
}
ngOnInit() {
this.accordions = [
{ title: this.title1, child: ['content 1', 'content 1', 'content 1'] },
{
title: this.title2,
child: ['content 2', 'content 2', 'content 2'],
inactive: false
},
{ title: 'Title 3', child: ['content 3', 'content 3', 'content 3'], inactive: true }
];
}
}
手风琴模式
import { Component } from '@angular/core';
@Component({
selector: 'demo-accordion-accordion',
template: `
<Accordion [accordion]="true" [defaultActiveKey]="'0'" [activeKey]="activeKey" (onChange)="onChange($event)">
<AccordionPanel
*ngFor="let item of accordions; let i = index"
[key]="i"
[header]="item.title"
[disabled]="item.inactive"
>
<List className="my-list">
<ListItem *ngFor="let content of item.child">
{{ content }}
</ListItem>
</List>
</AccordionPanel>
</Accordion>
`
})
export class DemoAccordionAccordionComponent {
activeKey = [1];
accordions: Array<any> = [
{ title: 'Title 1', child: ['content 1', 'content 1', 'content 1'] },
{ title: 'Title 2', child: ['content 2', 'content 2', 'content 2'] },
{ title: 'Title 3', child: ['content 3', 'content 3', 'content 3'] }
];
onChange(event) {
console.log(event);
}
}
API
Accordion
参数 | 说明 | 类型 | 默认值 |
---|---|---|---|
[activeKey] | 当前激活 tab 面板的 key, accordion模式下默认第一个元素 | Array | string | - |
[defaultActiveKey] | 初始化选中面板的 key | string | - |
[accordion] | 手风琴 模式 | boolean | false |
(onChange) | 切换面板的回调 | EventEmitter<string> | - |
AccordionPanel
参数 | 说明 | 类型 | 默认值 |
---|---|---|---|
[key] | 对应 activeKey | string | - |
[header] | 面板头内容 | string | TemplateRef | - |
注意: 目前暂不支持嵌套使用