使用AEM SPA编辑器嵌入REACT应用程序并与AEM Screens Analytics集成 embedding-a-react-application-using-the-aem-spa-editor-and-integrating-with-aem-screens-analytics
本节介绍如何使用AEM SPA编辑器(可由AEM中的业务专业人员配置)使用REACT(或Angular)嵌入交互式单页应用程序,以及如何将交互式应用程序与离线Adobe Analytics集成。
使用AEM SPA编辑器 using-the-aem-spa-editor
请按照以下步骤使用AEM SPA编辑器:
-
克隆AEM SPA Editor存储库: https://github.com/adobe/aem-spa-project-archetype.
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 我们使用 组ID 作为 com.adobe.aem.screens 和 ArtifactId 作为 我的示例SPA (这是默认设置)。 您可以根据需要选择自己的。 -
创建项目后,请使用所选的IDE或编辑器并导入生成的Maven项目。
-
使用命令部署到本地AEM实例 mvn全新安装 — PautoInstallPackage.
在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项目。 请参阅 创建和管理项目 了解更多详细信息。
-
新建 应用程序渠道 (优选)(或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 了解如何使用AEM Screens在Adobe Analytics中执行排序以及使用离线Adobe Analytics发送自定义事件。
-
在所选的IDE/编辑器中编辑react应用程序(尤其是文本组件或要开始发送事件的其他组件)。
-
在要为组件捕获的单击事件或其他事件上,使用标准数据模型添加Analytics信息。
请参阅 使用AEM Screens配置Adobe Analyticss以了解更多详细信息。
-
调用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 播放器固件会自动将有关播放器及其运行时环境的更多详细信息添加到您发送的自定义分析数据中。 因此,除非绝对必要,否则您可能不需要捕获低级别的操作系统/设备详细信息。 您只需专注于业务分析数据即可。