使用AEM SPA编辑器嵌入REACT应用程序并与AEM Screens Analytics集成 embedding-a-react-application-using-the-aem-spa-editor-and-integrating-with-aem-screens-analytics
您可以使用REACT(或Angular)嵌入交互式单页应用程序。 您可以使用AEM SPA中的业务专业人员配置的AEM编辑器来执行此操作。 您还可以了解如何将交互式应用程序与离线Adobe Analytics集成。
使用AEM SPA编辑器 using-the-aem-spa-editor
请按照以下步骤使用AEM SPA编辑器:
-
在https://github.com/adobe/aem-spa-project-archetype.处克隆AEM SPA Editor存储库
note note NOTE 此原型创建一个规模最小的Adobe Experience Manager项目作为您自己的SPA项目的起点。 使用此原型时必须提供的属性允许您根据需要命名此项目的所有部分。 -
要创建AEM SPA编辑器原型项目,请按照自述文件说明:
code language-none mvn clean install archetype:update-local-catalog mvn archetype:crawl mvn archetype:generate \ -DarchetypeCatalog=internal \ -DarchetypeGroupId=com.adobe.cq.spa.archetypes \ -DarchetypeArtifactId=aem-spa-project-archetype \ -DarchetypeVersion=1.0.3-SNAPSHOT \
note note NOTE 此文档使用 GroupId 作为 com.adobe.aem.screens,使用 ArtifactId 作为 我的示例SPA(默认值)。 您可以根据需要选择自己的。 -
创建项目后,使用您选择的IDE或编辑器并导入生成的Maven项目。
-
使用命令 mvn clean install -PautoInstallPackage 部署到本地AEM实例。
在REACT应用程序中编辑内容 editing-content-in-the-react-app
要编辑REACT应用程序中的内容,请执行以下操作:
- 导航到
https://localhost:4502/editor.html/content/mysamplespa/en/home.html
(替换适用的主机名、端口和项目名称)。 - 能够编辑Hello World应用程序中显示的文本。
将交互式REACT应用程序添加到AEM Screens adding-the-interactive-react-app-to-aem-screens
执行以下步骤,将交互式REACT应用程序添加到AEM Screens:
-
创建一个AEM Screens项目。 有关详细信息,请参阅创建和管理项目。
-
在AEM Screens项目的 Channels 文件夹中创建一个 应用程序渠道(最好是)(或1x1模板或多区域渠道)。
note note NOTE 不建议在此使用案例中使用 序列渠道,因为它们本身带有幻灯片放映逻辑,与体验的交互性质冲突。
有关详细信息,请参阅创建和管理渠道。 -
编辑任意序列渠道并拖放嵌入的页面组件。
有关更多详细信息,请参阅将组件添加到渠道。
note note NOTE 确保在为显示分配渠道时添加用户交互事件。 -
单击操作栏中的 编辑,以便编辑渠道的属性。
-
拖放 嵌入式页面 组件,或在应用程序渠道中重用现有组件,然后单击mysamplespa应用程序下的主页,例如 /content/mysamplespa/en/home。
-
将渠道分配给显示。
note note NOTE 确保在为显示分配渠道时添加用户交互事件。 -
注册此项目的播放器并将其分配给显示区。 您现在可以看到交互式应用程序正在AEM Screens上运行。
有关注册设备的详细信息,请参阅设备注册。
通过AEM Screens将SPA与Adobe Analytics与离线功能集成 integrating-the-spa-with-adobe-analytics-with-offline-capability-through-aem-screens
请按照以下步骤通过AEM Screens将SPA与Adobe Analytics与离线功能集成:
-
在AEM Screens中配置Adobe Analytics。
有关如何使用AEM Screens在Adobe Analytics中执行排序以及使用离线Adobe Analytics发送自定义事件的更多信息,请参阅使用AEM Screens配置Adobe Analytics。
-
在所选的IDE/编辑器中编辑react应用程序(特别是文本组件或要开始发送事件的其他组件)。
-
在您要为组件捕获的单击事件或其他事件上,使用标准数据模型添加分析信息。
有关详细信息,请参阅使用AEM Screens配置Adobe Analytics。
-
调用AEM Screens Analytics API,以便您可以离线保存事件并将其突发发送到Adobe Analytics。
例如,
code language-none handleClick() { if ((window.parent) && (window.parent.CQ) && (window.parent.CQ.screens) && (window.parent.CQ.screens.analytics)) { var analyticsEvent = {}; analyticsEvent['event.type'] = 'play'; // Type of event analyticsEvent['event.coll_dts'] = new Date().toISOString(); // Start of collecting the event analyticsEvent['event.dts_start'] = new Date().toISOString(); // Event start analyticsEvent['content.type'] = 'Washing machine'; // Mime Type or product category analyticsEvent['content.action'] = 'Path to the washing machine asset in AEM'; // Path in AEM to relevant asset analyticsEvent['trn.product'] = 'Washing machine Model number'; // Product being explored analyticsEvent['trn.amount'] = 1000; // Product pricing or other numeric value or weight analyticsEvent['event.dts_end'] = new Date().toISOString(); // Event end analyticsEvent['event.count'] = 100; // Numeric value that may count a number of clicks or keystrokes or wait time in seconds for example analyticsEvent['event.value'] = 'My favorite analytics event'; analyticsEvent['trn.quantity'] = 10; // Quantity of product selection analyticsEvent['event.subtype'] = 'end'; // Event subtype if applicable window.parent.CQ.screens.analytics.sendTrackingEvent(analyticsEvent); } }
note note NOTE 播放器固件会自动将有关播放器及其运行时环境的更多详细信息添加到您发送的自定义分析数据中。 因此,除非必要,否则您可能必须捕获低级操作系统/设备详细信息。 专注于业务分析数据。