Angular Tree Grid Size
El diseño de IgxTreeGrid se basa en las Pautas de diseño de materiales. Actualmente ofrecemos una opción para elegir entre un conjunto predefinido de opciones de tamaño que brindarán una vista pequeña, mediana o grande respectivamente. Al seleccionar el tamaño correcto para su tabla Material UI/cuadrícula Material UI, puede mejorar significativamente la experiencia del usuario al interactuar con grandes cantidades de contenido.
Angular Tree Grid Size Example
Usage
Como puede ver en la demostración anterior, IgxTreeGrid ofrece tres opciones de tamaño: pequeño, mediano y grande. El siguiente fragmento de código muestra cómo configurar el tamaño:
<igx-tree-grid #treeGrid [data]="data" style="--ig-size: var(--ig-size-small)">
</igx-tree-grid>
Y ahora veamos en detalle cómo se refleja cada opción en el componente Tree Grid. Cuando cambia entre diferentes tamaños, se cambiará la altura de cada elemento de Tree Grid y los rellenos correspondientes. Además, si desea aplicar un ancho de columna personalizado, considere el hecho de que debe ser mayor que la suma del relleno izquierdo y derecho.
- --ig-size-large: este es el tamaño predeterminado de la cuadrícula de árbol con la intensidad más baja y una altura de fila igual a
50px
. Los rellenos izquierdo y derecho son24px
;width
mínimo de columna es80px
; - --ig-size-medium: este es el tamaño medio con una altura de fila
40px
. Los rellenos izquierdo y derecho son16px
;width
mínimo de columna es64px
; - --ig-size-small: este es el tamaño más pequeño con una altura de fila
32px
. Los rellenos izquierdo y derecho son12px
;width
mínimo de columna es56px
;
Note
Tenga en cuenta que actualmente no puede anular ninguno de los tamaños.
Continuemos ahora con nuestro ejemplo y veamos en acción cómo se aplica cada tamaño. Primero agreguemos un botón que nos ayudará a cambiar entre cada tamaño:
<div class="density-chooser">
<igx-buttongroup [values]="sizes"></igx-buttongroup>
</div>
@ViewChild(IgxButtonGroupComponent) public buttonGroup: IgxButtonGroupComponent;
public size = 'small';
public sizes;
public ngOnInit() {
this.sizes = [
{
label: 'small',
selected: this.size === 'small',
togglable: true
},
{
label: 'medium',
selected: this.sie === 'medium',
togglable: true
},
{
label: 'large',
selected: this.size === 'large',
togglable: true
}
];
}
Ahora podemos agregar el marcado.
<div class="density-chooser">
<igx-buttongroup [values]="sizes" (selected)="selectSize($event)"></igx-buttongroup>
</div>
<igx-tree-grid #treeGrid [data]="data" primaryKey="ID" foreignKey="ParentID" width="100%"
height="550px" [allowFiltering]="true">
<igx-column field="Name" dataType="string" [sortable]="true" [hasSummary]="true" width="200px"></igx-column>
<igx-column-group [pinned]="false" header="General Information">
<igx-column field="HireDate" dataType="date" [sortable]="true" [hasSummary]="true">
<ng-template igxCell let-cell="cell" let-val>
{{val | date:'dd/MM/yyyy'}}
</ng-template>
</igx-column>
<igx-column-group header="Person Details">
<igx-column field="ID" dataType="number" [filterable]="false"></igx-column>
<igx-column field="Title" dataType="string" [sortable]="true" [hasSummary]="true"></igx-column>
<igx-column field="Age" dataType="number" [sortable]="true" [hasSummary]="true"
[summaries]="numberSummaries" [filterable]="false"></igx-column>
</igx-column-group>
</igx-column-group>
<igx-column-group header="Address Information">
<igx-column-group header="Location">
<igx-column field="Country" dataType="string" [sortable]="true" [hasSummary]="true"></igx-column>
<igx-column field="City" dataType="string" [sortable]="true" [hasSummary]="true"></igx-column>
<igx-column field="Address" dataType="string" [sortable]="true" [hasSummary]="true"></igx-column>
</igx-column-group>
<igx-column-group header="Contact Information">
<igx-column field="Phone" dataType="string" [sortable]="true" [hasSummary]="true"></igx-column>
<igx-column field="Fax" dataType="string" [sortable]="true" [hasSummary]="true"></igx-column>
<igx-column field="PostalCode" dataType="string" [sortable]="true" [hasSummary]="true"></igx-column>
</igx-column-group>
</igx-column-group>
<igx-column-group header="Address Information">
<igx-column-group header="Location">
<igx-column field="Country" dataType="string" [sortable]="true" [hasSummary]="true"></igx-column>
<igx-column field="City" dataType="string" [sortable]="true" [hasSummary]="true"></igx-column>
<igx-column field="Address" dataType="string" [sortable]="true" [hasSummary]="true"></igx-column>
</igx-column-group>
<igx-column-group header="Contact Information">
<igx-column field="Phone" dataType="string" [sortable]="true" [resizable]="true"></igx-column>
<igx-column field="Fax" dataType="string" [sortable]="true" [resizable]="true"></igx-column>
<igx-column field="PostalCode" dataType="string" [sortable]="true" [resizable]="true"></igx-column>
</igx-column-group>
</igx-column-group>
</igx-tree-grid>
Finalmente, proporcionemos la lógica necesaria para aplicar realmente el tamaño:
@ViewChild('treeGrid', { read: IgxTreeGridComponent })
public treeGrid: IgxTreeGridComponent;
public selectSize(event: any) {
this.size = this.sizes[event.index].label;
}
@HostBinding('style.--ig-size')
protected get sizeStyle() {
return `var(--ig-size-${this.size})`;
}
Otra opción que te brinda IgxTreeGrid, para poder cambiar la altura de las filas en el Tree Grid, es la propiedad rowHeight
. Entonces, veamos en acción cómo esta propiedad afecta el diseño de la cuadrícula de árbol junto con la variable CSS--ig-size
.
Por favor tenga en cuenta lo siguiente:
- --La variable CSS
--ig-size
NO tendrá impacto en la altura de la fila si se especifica RowHeight; --ig-size
afectará a todos los elementos restantes en Tree Grid, como se describió anteriormente;
Y ahora podemos ampliar nuestro ejemplo y agregar la propiedad rowHeight
a Tree Grid:
<igx-tree-grid #treeGrid [data]="data" [rowHeight]="'80px'" width="100%"
height="550px" [allowFiltering]="true">
..............
</igx-tree-grid>
API References
Additional Resources
- Descripción general de la cuadrícula de árbol
- Virtualización y rendimiento
- Edición
- Paginación
- Filtración
- Clasificación
- resúmenes
- Fijación de columnas
- Cambio de tamaño de columna
- Selección
- buscando