在SAP Commerce中,我准备了自定义CMS组件。我把它放在正确的插槽中。斯巴达克斯(Spartacus)收到有关它的信息-我可以看到此组件在页面上的正确位置。但是如何从该组件中检索一些数据。在给定的插槽中,响应如下:
"components": {
"component": [
{
"uid": "NewsletterComponent",
"uuid": "eyJpdGVtSWQiOiJOZXdzbGV0dGVyQ29tcG9uZW50IiwiY2F0YWxvZ0lkIjoiZWxlY3Ryb25pY3Mtc3BhQ29udGVudENhdGFsb2ciLCJjYXRhbG9nVmVyc2lvbiI6Ik9ubGluZSJ9",
"typeCode": "NewsletterComponent",
"modifiedTime": "2020-04-02T21:57:10.236+02:00",
"name": "Newsletter Component",
"container": "false",
"mailPlaceholder": "Your email address",
"mailHeaderText": "E-mail Newsletter"
}
如何从angular检索此数据? 我创建了一些组件,但是它不起作用
import { Component, ChangeDetectionStrategy, OnInit } from '@angular/core';
import { CmsComponentData } from '@spartacus/storefront';
import { CmsComponent, CmsService } from '@spartacus/core'
import { Observable } from 'rxjs';
@Component({
selector: 'app-newsletter',
templateUrl: './newsletter.component.html',
styleUrls: ['./newsletter.component.scss'],
changeDetection: ChangeDetectionStrategy.OnPush
})
export class NewsletterComponent extends CmsComponentData<CmsComponent> {
component: Observable<any>;
constructor(cmsService: CmsService) {
super();
this.component = cmsService.getComponentData('NewsletterComponent')
}
public getText(): any {
console.log(this.component)
}
}
我将其注册到模块
B2cStorefrontModule.withConfig({
cmsComponents: {
NewsletterComponent: {
component: NewsletterComponent
}
},
我可以从服务器响应中检索mailPlaceholder和mailHeader文本吗?
答案 0 :(得分:1)
您的组件需要在构造函数中接受组件数据,例如:https://sap.github.io/spartacus/components/ParagraphComponent.html#source
答案 1 :(得分:0)
好的,现在可以使用了:)
import { Component, ChangeDetectionStrategy, OnInit } from '@angular/core';
import { CmsComponentData } from '@spartacus/storefront';
import { CmsNewsletterComponent } from '../CmsNewsletterComponent';
@Component({
selector: 'app-newsletter',
templateUrl: './newsletter.component.html',
styleUrls: ['./newsletter.component.scss'],
changeDetection: ChangeDetectionStrategy.OnPush
})
export class NewsletterComponent implements OnInit {
constructor(public component: CmsComponentData<CmsNewsletterComponent>) {
}
cmsComp: CmsNewsletterComponent;
ngOnInit(): void {
this.component.data$.subscribe(comp => this.cmsComp = comp);
}
}
现在我可以完全访问组件数据了