我在服务公共领域:
@Injectable()
export class ShareDataService {
// some code
public templateForCurrencyCOS;
public templateForPercentCOS;
public templateForCurrencyCOGS;
public templateForPercentCOGS;
// some code
}
实际上,通过订阅其他HeaderComponent
在revenueService
中设置了该字段的值:
export class HeaderComponent implements OnInit, OnDestroy {
constructor(
private revenueService: RevenueService
) {}
ngOnInit() {
this.addCOSItemCurrencyTemplate();
this.addCOSItemPercentTemplate();
this.addCOGSItemCurrencyTemplate();
this.addCOGSItemPercentTemplate();
}
addCOSItemCurrencyTemplate() {
if (!this.shareDataService.templateForCurrencyCOS) {
this.revenueService.addCostOfSellingItemCurrencyNew().subscribe(
response => {
this.shareDataService.templateForCurrencyCOS = response;
}, error => {
console.log(error);
});
}
}
addCOSItemPercentTemplate() {
if (!this.shareDataService.templateForPercentCOS) {
this.revenueService.addCOSPercentNew().subscribe(response =>{
this.shareDataService.templateForPercentCOS = response;
}, error => {
console.log(error);
});
}
addCOGSItemCurrencyTemplate() {
// similar implementation like addCOSItemPercentTemplate and addCOSItemCurrencyTemplate
}
addCOGSItemPercentTemplate() {
// similar implementation like addCOSItemPercentTemplate and addCOSItemCurrencyTemplate
}
}
}
有时在这里,我得到undefined
this.shareDataService.templateForCurrencyCOGS
以及
this.shareDataService.templateForCurrencyCOS
,
this.shareDataService.templateForPercentCOGS
,
this.shareDataService.templateForPercentCOS
export class RevenueAssistantComponent implements OnInit {
ngOnInit() {
this.templateForCurrencyCOGS = {...
this.shareDataService.templateForCurrencyCOGS,
fields: [...this.shareDataService.templateForCurrencyCOGS.fields]
};
this.templateForPercentCOGS = {...
this.shareDataService.templateForPercentCOGS,
fields: [...this.shareDataService.templateForPercentCOGS && this.shareDataService.templateForPercentCOGS.fields]
};
this.templateForCurrencyCOS = {
...this.shareDataService.templateForCurrencyCOS,
fields: [...this.shareDataService.templateForCurrencyCOS && this.shareDataService.templateForCurrencyCOS.fields]
};
this.templateForPercentCOS = {
...this.shareDataService.templateForPercentCOS,
fields: [...this.shareDataService.templateForPercentCOS &&
this.shareDataService.templateForPercentCOS.fields]
};
}
}
我猜想RevenueAssistantComponent
在HeaderComponent
设置字段值和解决方法之前是在RevenueAssistantComponent
本身中解决此问题的原因是
在HeaderComponent
字段的shareDataService
设置值中,body
{
background: #c0c0c0;
}
#block_with_line
{
width: 100%;
position: relative;
height: 18px;
background: url('');
}
#block_with_line span
{
background: #e4e4e4;
width: 150px;
display: block;
margin: 0 auto;
position: absolute;
left: 50%;
margin-left: -75px;
text-align: center
}
总是在之后获取模板值。但是我不知道如何实现
答案 0 :(得分:0)
在声明时初始化将解决错误。
public templateForCurrencyCOS = {}; or templateForCurrencyCOS = []; // for Arrays
public templateForPercentCOS = {};
public templateForCurrencyCOGS = {};
public templateForPercentCOGS = {};