我是angular2的新手,这就是我需要帮助的原因 我正在创建多步形式,我需要从另一个组件调用方法 我在这个组件模板中有SellComponent
<sell-wizard>
<sell-wizard-step></sell-wizard-step>
</sell-wizard>
我必须调用位于WizardComponent中的方法 以下来自组件的代码
WizardComponent
import { Component, Input, Output, EventEmitter } from '@angular/core';
@Component({
selector: 'sell-wizard',
template: "
<ng-content></ng-content>
<div
class="my-wizard__footer">
<button
[style.visibility]="isOnFirstStep() ? 'hidden' : 'visible'"
(click)="stepChange.emit(step - 1)">
Previous
</button>
{{step}} / {{steps}}
<button
*ngIf="!isOnFinalStep()"
(click)="stepChange.emit(step + 1)">
Next
</button>
<button
*ngIf="isOnFinalStep()"
(click)="finish.emit(step + 1)">
{{finishText}}
</button>
</div>",
})
export class WizardComponent {
@Input() finishText = 'Finish';
@Input() step = 1;
@Output() finish = new EventEmitter();
@Output() stepChange = new EventEmitter();
private steps = 0;
private isOnFinalStep = () => this.step === this.steps;
private isOnFirstStep = () => this.step === 1;
public addStep() {
const newSteps = this.steps + 1;
this.steps = newSteps;
return newSteps;
}}
WizardStepComponent
import { Component, Input } from '@angular/core';
import { WizardComponent } from './wizard.component';
@Component({
selector: 'sell-wizard-step',
host: {
'[style.display]': 'isCurrent ? "block" : "none"',
},
template: `<ng-content></ng-content>`,
})
export class WizardStepComponent {
private isCurrent;
private step;
constructor(
private parent:WizardComponent
) {}
ngOnInit() {
this.step = this.parent.addStep();
this.isCurrent = this.step === this.parent.step;
this.parent.stepChange.subscribe(step => {
this.isCurrent = this.step === step;
});
}
}
SellComponent
import { Component, Input} from '@angular/core';
@Component({
moduleId: module.id,
selector: 'sell',
templateUrl: 'sell.component.html'
})
export class SellComponent {
private step = 1;
constructor(){}
}
所以在这个SellComponent视图中,我试图从WizardComponent调用方法
<button type="button" (click)="stepChange.emit(step + 1)">next</button>
它说Cannot read property 'stepChange' of undefined
我如何从另一个组件调用fucntion?
谢谢你的帮助
答案 0 :(得分:0)
找到解决方案。感谢0x2D9A3
我们可以通过在WizardComponent
上声明属性来访问我们的SellComponent中的SellComponent: @ViewChild(WizardComponent) wizard;
,然后通过访问wizard.stepChange.