html - 具有旋转动态列的 Kendo Grid
问题描述
我正在尝试使用 Angular 生成具有动态生成列的 Kendo Grid。但是,我想匹配与该列对应的正确股票代码。这是我的代码:
<kendo-grid-column *ngFor="let column of tickerColumns" field="quantity" title="{{column.ticker}}">
<ng-template kendoGridEditTemplate let-dataItem="dataItem">
<input *ngIf="dataItem.ticker == column.ticker"
[(ngModel)]="dataItem.quantity"
[ngModelOptions]="{standalone: true}" class="k-textbox" required />
</ng-template>
</kendo-grid-column>
该tickerColumns
数组只是一个包含三个股票代码的数组。主要数据结构如下所示:
但是,结果不是我所期望的,好像 ngIf 子句没有发挥应有的作用。
解决方案
我在 Telerik 的人员的帮助下解决了这个问题,他们指示我使用kendoGridCellTemplate
而不是kendoGridEditTemplate
指令。但是这样做,即使您不编辑该行,单元格也将始终是可编辑的。您必须在视图模型中拥有一个isEditing
属性(我已经拥有)并使用此布尔值来启用或禁用包含如下值的文本框:
HTML
<kendo-grid-column field="quantity" title="{{column.ticker}}" *ngFor="let column of tickerColumns;">
<ng-template kendoGridCellTemplate let-dataItem>
<input *ngIf="dataItem.ticker == column.ticker"
[disabled]="!dataItem.isEditing"
[(ngModel)]="dataItem.quantity"
[ngModelOptions]="{standalone: true}" class="k-textbox" required />
</ng-template>
</kendo-grid-column>
在编辑模式下(即单击单行旁边的编辑按钮时)只需切换该 dataItem 的 isEditing 值。当您取消或保存并结束编辑时,再次切换它。您现在拥有 Kendo Angular 的自定义枢轴网格:
推荐阅读
- python - python beautifullsoup websocket
- javascript - 可选择通过指令将数据传递给子元素
- jenkins - 如何生成声纳分析文件作为构建的一部分以便能够处理这些文件?
- api - 无法解析 HTTP 请求
- javascript - 无法读取 null React 的属性“样式”
- django - Django 嵌套模板
- javascript - Laravel 5.6 如何将 URL 作为 URL 参数传递?
- c++builder - 窗口屏幕应用程序行为,如屏幕键盘
- google-analytics - 谷歌分析 - 产品列表视图 - 谷歌如何计算指标?
- servicenow - ServiceNow 个人开发者实例启用了 SecurityOperations 插件?