如何使 PrimeNG table 列自动适应?
how to make PrimeNG table columns auto fit?
我想让我的 PrimeNG table 列自动适应和调整大小。我怎样才能做到这一点?
我使用了以下代码。
在 SCSS 中更改设置 table-layout:auto !important;
.html
<p-dataTable [value]="Dataset" [style]="{'width':'100%','overflow':'auto!important'}"
[responsive]="true" [rows]="20"
[resizableColumns]="true"
columnResizeMode="expand"
[immutable]=false
[paginator]="true" [rowsPerPageOptions]="[10,15,20,25]"
appendTo="body" #dt>
<p-column styleClass="checkbox ui-resizable-column" [style]="{'width': 'auto'}" selectionMode="multiple">
</p-column>
<p-column *ngFor="let col of cols;let j=index;" [style]="{'width':'auto','display':col.display} " [field]="col.field" [header]="col.header"
[sortable]="true" [filter]="true" filterPlaceholder="Search" (mouseleave)="hoveredIndex=null" filterPlaceholder="Search"
appendTo="body">
<ng-template let-row="rowData" let-i="rowIndex" pTemplate="body">
<div [pTooltip]="row[col.field]" [id]="col.field"></div>
<!-- set String -->
<span (click)="test(dt)" style="text-align:left;" *ngIf="col.datatype!='int' && col.datatype!='float'">
{{row[col.field]}}
</span>
<!-- set int -->
<span (click)="test(dt)" style="text-align:top;float: top;padding-top: 4px !important;" *ngIf="col.datatype=='int' || col.datatype=='float' ">
{{row[col.field]}}
</span>
</ng-template>
</p-column>
</p-dataTable>
.scss
@import "src/app/Themes/colorVariables"; //datatable ui
//Updated row
::ng-deep .ui-datatable tbody > tr.ng-star-inserted.ui-widget-updated-row{
background-color:$updated-row-color;
}
::ng-deep .ui-datatable tbody > tr>td.ui-widget-deleted-row-checkbox .ui-chkbox{
display: none;
}
//Deleted row
::ng-deep .ui-datatable tbody > tr.ng-star-inserted.ui-widget-deleted-row{
background-color:$deleted-row-color;
}
::ng-deep .ui-datatable table
{
table-layout:auto !important;
overflow-y: scroll !important;
}
::ng-deep .ui-datatable-tablewrapper {
overflow-y: scroll !important;
width: auto !important;
}
::ng-deep .ui-datatable-resizable {
padding-bottom: 1px;
/* overflow: auto; */
width: auto !important;
}
::ng-deep .ui-datatable-scrollable-view .ui-datatable-scrollable-body {
// min-height: 300px;
border: 1px solid #D5D5D5;
}
::ng-deep .ui-datatable tbody > tr.ui-widget-content.ui-state-highlight{
background-color: darkkhaki !important;
}
::ng-deep a.ui-state-highlight , .ui-state-highlight{
background-color: rgb(64, 153, 83);
color: black;
}
.hoverAction:hover{
background-color: seagreen;
color: black;
}
::ng-deep .ui-confirmdialog-message {
white-space: pre-line;
}
::ng-deep .ui-datatable tr.ui-datatable-even:hover
{ background: #78BCFF;
}
::ng-deep .ui-datatable tbody > tr.ui-widget-content.ui-datatable-odd:hover {
background: #78BCFF;
}
.ui-datatable .ui-datatable-thead>tr>th, .ui-datatable .ui-datatable-tfoot>tr>td, .ui-datatable .ui-datatable-data>tr>td {
border-color: inherit;
-webkit-box-sizing: border-box;
box-sizing: border-box;
padding: .25em .5em;
border-width: 1px;
flex: 2;
//width:auto !important;
min-height: 8px;
min-width: auto !important;
max-width: 300px !important;
font-size: 12px;
padding: 0px !important;
padding-left: 4px !important;
color: black;
text-transform: capitalize;
white-space: nowrap;
overflow: hidden;
display: table-cell;
text-overflow: ellipsis !important;
word-wrap: break-word !important;
/* font-size: 11px; */
font-family: $default-font-family;
border-width: 1px;
border-style: solid;
}
您需要使用 2 个属性 [resizableColumns]="true" [autoLayout]="true" <p-table>
标签
中定义如下
<p-table [resizableColumns]="true" [autoLayout]="true">
为什么会这样?
如果您检查它,primeng 默认情况下会从 primeng.min.css 文件
添加以下代码
.ui-table table {
border-collapse: collapse;
width: 100%;
table-layout: fixed;
}
您需要更改 table-layout 属性 ,为此您需要使用 [autoLayout]="true"。
还有另一种方法,您可以使用 :host 覆盖它,但我不推荐它,因为 autoLayout 已经可以使用了。
对于调整大小,您需要在标签
中使用[resizableColumns]="true"
对于滚动,您需要在标签
中使用[scrollable]="true" scrollHeight="300px"
使用跟随内联css
table-layout: fixed;
在 PrimeNG 13 中使用带有动态数据和自动列宽的 table 我必须手动将宽度设置为“max-content”:[tableStyle]="{width: 'max-content'}"
.
代码示例:
<p-table [columns]="columns"
[value]="tableData"
styleClass="p-datatable-gridlines"
scrollHeight="42.857rem"
scrollDirection="horizontal"
responsiveLayout="scroll"
[tableStyle]="{ width: 'max-content'}">
<ng-template pTemplate="header" let-columns>
<tr>
<th *ngFor="let col of columns" class="p-1">
{{col}}
</th>
</tr>
</ng-template>
<ng-template pTemplate="body" let-rowData let-columns="columns">
<tr>
<td *ngFor="let col of columns" class="p-1">
{{rowData[col]}}
</td>
</tr>
</ng-template>
</p-table>
我想让我的 PrimeNG table 列自动适应和调整大小。我怎样才能做到这一点?
我使用了以下代码。 在 SCSS 中更改设置 table-layout:auto !important; .html
<p-dataTable [value]="Dataset" [style]="{'width':'100%','overflow':'auto!important'}"
[responsive]="true" [rows]="20"
[resizableColumns]="true"
columnResizeMode="expand"
[immutable]=false
[paginator]="true" [rowsPerPageOptions]="[10,15,20,25]"
appendTo="body" #dt>
<p-column styleClass="checkbox ui-resizable-column" [style]="{'width': 'auto'}" selectionMode="multiple">
</p-column>
<p-column *ngFor="let col of cols;let j=index;" [style]="{'width':'auto','display':col.display} " [field]="col.field" [header]="col.header"
[sortable]="true" [filter]="true" filterPlaceholder="Search" (mouseleave)="hoveredIndex=null" filterPlaceholder="Search"
appendTo="body">
<ng-template let-row="rowData" let-i="rowIndex" pTemplate="body">
<div [pTooltip]="row[col.field]" [id]="col.field"></div>
<!-- set String -->
<span (click)="test(dt)" style="text-align:left;" *ngIf="col.datatype!='int' && col.datatype!='float'">
{{row[col.field]}}
</span>
<!-- set int -->
<span (click)="test(dt)" style="text-align:top;float: top;padding-top: 4px !important;" *ngIf="col.datatype=='int' || col.datatype=='float' ">
{{row[col.field]}}
</span>
</ng-template>
</p-column>
</p-dataTable>
.scss
@import "src/app/Themes/colorVariables"; //datatable ui
//Updated row
::ng-deep .ui-datatable tbody > tr.ng-star-inserted.ui-widget-updated-row{
background-color:$updated-row-color;
}
::ng-deep .ui-datatable tbody > tr>td.ui-widget-deleted-row-checkbox .ui-chkbox{
display: none;
}
//Deleted row
::ng-deep .ui-datatable tbody > tr.ng-star-inserted.ui-widget-deleted-row{
background-color:$deleted-row-color;
}
::ng-deep .ui-datatable table
{
table-layout:auto !important;
overflow-y: scroll !important;
}
::ng-deep .ui-datatable-tablewrapper {
overflow-y: scroll !important;
width: auto !important;
}
::ng-deep .ui-datatable-resizable {
padding-bottom: 1px;
/* overflow: auto; */
width: auto !important;
}
::ng-deep .ui-datatable-scrollable-view .ui-datatable-scrollable-body {
// min-height: 300px;
border: 1px solid #D5D5D5;
}
::ng-deep .ui-datatable tbody > tr.ui-widget-content.ui-state-highlight{
background-color: darkkhaki !important;
}
::ng-deep a.ui-state-highlight , .ui-state-highlight{
background-color: rgb(64, 153, 83);
color: black;
}
.hoverAction:hover{
background-color: seagreen;
color: black;
}
::ng-deep .ui-confirmdialog-message {
white-space: pre-line;
}
::ng-deep .ui-datatable tr.ui-datatable-even:hover
{ background: #78BCFF;
}
::ng-deep .ui-datatable tbody > tr.ui-widget-content.ui-datatable-odd:hover {
background: #78BCFF;
}
.ui-datatable .ui-datatable-thead>tr>th, .ui-datatable .ui-datatable-tfoot>tr>td, .ui-datatable .ui-datatable-data>tr>td {
border-color: inherit;
-webkit-box-sizing: border-box;
box-sizing: border-box;
padding: .25em .5em;
border-width: 1px;
flex: 2;
//width:auto !important;
min-height: 8px;
min-width: auto !important;
max-width: 300px !important;
font-size: 12px;
padding: 0px !important;
padding-left: 4px !important;
color: black;
text-transform: capitalize;
white-space: nowrap;
overflow: hidden;
display: table-cell;
text-overflow: ellipsis !important;
word-wrap: break-word !important;
/* font-size: 11px; */
font-family: $default-font-family;
border-width: 1px;
border-style: solid;
}
您需要使用 2 个属性 [resizableColumns]="true" [autoLayout]="true" <p-table>
标签
<p-table [resizableColumns]="true" [autoLayout]="true">
为什么会这样? 如果您检查它,primeng 默认情况下会从 primeng.min.css 文件
添加以下代码.ui-table table {
border-collapse: collapse;
width: 100%;
table-layout: fixed;
}
您需要更改 table-layout 属性 ,为此您需要使用 [autoLayout]="true"。 还有另一种方法,您可以使用 :host 覆盖它,但我不推荐它,因为 autoLayout 已经可以使用了。
对于调整大小,您需要在标签
中使用[resizableColumns]="true"对于滚动,您需要在标签
中使用[scrollable]="true" scrollHeight="300px"使用跟随内联css
table-layout: fixed;
在 PrimeNG 13 中使用带有动态数据和自动列宽的 table 我必须手动将宽度设置为“max-content”:[tableStyle]="{width: 'max-content'}"
.
代码示例:
<p-table [columns]="columns"
[value]="tableData"
styleClass="p-datatable-gridlines"
scrollHeight="42.857rem"
scrollDirection="horizontal"
responsiveLayout="scroll"
[tableStyle]="{ width: 'max-content'}">
<ng-template pTemplate="header" let-columns>
<tr>
<th *ngFor="let col of columns" class="p-1">
{{col}}
</th>
</tr>
</ng-template>
<ng-template pTemplate="body" let-rowData let-columns="columns">
<tr>
<td *ngFor="let col of columns" class="p-1">
{{rowData[col]}}
</td>
</tr>
</ng-template>
</p-table>