在指令的主机侦听器中访问模板变量
Accessing template variable in directive's host listener
鉴于以下情况,是否可以从 onvalueChanged 主机侦听器中的模板访问 'habitCellInfo'?
<div *dxTemplate="let habitCellInfo of 'habitEditCellTemplate'">
<dx-select-box
(onValueChanged)="
onHabitEditorValueChanged($event, habitCellInfo)
"
[dataSource]="habitsDataSrc"
[value]="habitCellInfo.data.habit"
pimDxSelectBox
>
<dx-validator>
<dxi-validation-rule
pimDxiValidationRule
rule="noun"
></dxi-validation-rule>
</dx-validator>
</dx-select-box>
</div>
import { DxSelectBoxComponent } from 'devextreme-angular';
import DataSource from 'devextreme/data/data_source';
import {
Directive, ElementRef, HostListener, Input, NgModule, OnInit, Renderer2, Self
} from '@angular/core';
import { addSelectBoxCustomItem } from '@pim/common/shared-dx/util';
import { PimDxModules } from '../modules/pim-dx-modules.module';
@Directive({
selector: '[pimDxSelectBox]',
})
export class PimDxSelectBoxDirective implements OnInit {
@Input() acceptCustomValue = true
@Input() dataSource!: DataSource
// Inject an instance of select-box
constructor(
private elRef: ElementRef,
@Self() private readonly selectBox: DxSelectBoxComponent,
private renderer: Renderer2,
) {}
ngOnInit(): void {
this.selectBox.acceptCustomValue = this.acceptCustomValue
this.selectBox.dataSource = this.dataSource
this.selectBox.grouped = this.grouped
}
@HostListener('onValueChanged', ['$event'])
editorValueChanged(e: Event) {
// HOW DO I
}
}
向您的指令添加一个输入,并从包含的模板传递单元格信息。
在指令中:
@Input() pimDxSelectBox: any;
在包含组件中:
[pimDxSelectBox]="habitCellInfo"
鉴于以下情况,是否可以从 onvalueChanged 主机侦听器中的模板访问 'habitCellInfo'?
<div *dxTemplate="let habitCellInfo of 'habitEditCellTemplate'">
<dx-select-box
(onValueChanged)="
onHabitEditorValueChanged($event, habitCellInfo)
"
[dataSource]="habitsDataSrc"
[value]="habitCellInfo.data.habit"
pimDxSelectBox
>
<dx-validator>
<dxi-validation-rule
pimDxiValidationRule
rule="noun"
></dxi-validation-rule>
</dx-validator>
</dx-select-box>
</div>
import { DxSelectBoxComponent } from 'devextreme-angular';
import DataSource from 'devextreme/data/data_source';
import {
Directive, ElementRef, HostListener, Input, NgModule, OnInit, Renderer2, Self
} from '@angular/core';
import { addSelectBoxCustomItem } from '@pim/common/shared-dx/util';
import { PimDxModules } from '../modules/pim-dx-modules.module';
@Directive({
selector: '[pimDxSelectBox]',
})
export class PimDxSelectBoxDirective implements OnInit {
@Input() acceptCustomValue = true
@Input() dataSource!: DataSource
// Inject an instance of select-box
constructor(
private elRef: ElementRef,
@Self() private readonly selectBox: DxSelectBoxComponent,
private renderer: Renderer2,
) {}
ngOnInit(): void {
this.selectBox.acceptCustomValue = this.acceptCustomValue
this.selectBox.dataSource = this.dataSource
this.selectBox.grouped = this.grouped
}
@HostListener('onValueChanged', ['$event'])
editorValueChanged(e: Event) {
// HOW DO I
}
}
向您的指令添加一个输入,并从包含的模板传递单元格信息。
在指令中:
@Input() pimDxSelectBox: any;
在包含组件中:
[pimDxSelectBox]="habitCellInfo"