【发布时间】:2019-11-21 16:49:36
【问题描述】:
我正在尝试通过 Telerik 的文档在剑道网格中添加一个复选框列。当我尝试选中或取消选中一行中的复选框时,它不起作用。
这是我的html:
<kendo-grid
[data]="gridView"
[selectable]="selectableSettings"
[height]="317"
[kendoGridSelectBy]="getWholeItemRow"
[selectedKeys]="mySelection"
(selectedKeysChange)="onSelectedKeysChange($event)"
(remove)="confirmDeleteItemFromGrid($event)">
<ng-template
kendoGridToolbarTemplate>
<button
[disabled]='mySelection.length === 0'
mat-flat-button
class="btn-danger btn-sm"
(click)="removeSelectedItems()">Remove selected items</button>
</ng-template>
<kendo-grid-checkbox-column width="15" showSelectAll="true" [columnMenu]="false" >
<ng-template kendoGridHeaderTemplate>
<input class="k-checkbox" id="selectAllCheckboxId" kendoGridSelectAllCheckbox
[state]="selectAllState"
(selectAllChange)="onSelectAllChange($event)">
<label class="k-checkbox-label"
for="selectAllCheckboxId"></label>
</ng-template>
</kendo-grid-checkbox-column>
...
</kendo-grid>
TS:
export class ImagesGridComponent implements OnInit{
@Input() captures: Array<Image>;
@Input() positionSection: number;
selectedImages: any[] = [];
public selectAllState: SelectAllCheckboxState = 'unchecked';
public mySelection: any[] = [];
public gridView: GridDataResult;
public selectableSettings: SelectableSettings = {
enabled: false,
checkboxOnly: false,
mode: 'multiple'
};
constructor(){}
ngOnInit(): void {
this.loadItems();
}
返回存储在行中的对象的函数。用于[kendoGridSelectBy]:
getWholeItemRow(context: RowArgs) {
return context.dataItem;
}
当 [selectedKeys] 集合更新时应该触发的函数:(不工作)
public onSelectedKeysChange(e) {
const len = this.mySelection.length;
if (len === 0) {
this.selectAllState = 'unchecked';
} else if (len > 0 && len < this.captures.length) {
this.selectAllState = 'indeterminate';
} else {
this.selectAllState = 'checked';
}
}
选中/取消选中标题复选框时使用的功能:
public onSelectAllChange(checkedState: SelectAllCheckboxState) {
if (checkedState === 'checked') {
this.mySelection = this.captures;
this.selectAllState = 'checked';
} else {
this.mySelection = [];
this.selectAllState = 'unchecked';
}
}
用于填充网格:
loadItems() {
this.gridView = {
data: this.captures,
total: this.captures.length
};
}
}
谢谢。
更新:
我编辑了 selectableSettings 对象,现在可以工作了:
public selectableSettings: SelectableSettings = {
enabled: true,
checkboxOnly: true,
mode: 'multiple'
};
【问题讨论】:
标签: angular kendo-ui kendo-grid