RemotePage 组件

上次更新: 2023-11-07
  • 主题:
  • Developing
    查看有关此主题的更多信息
  • 创建对象:
  • Developer

在决定外部SPA与AEM之间的集成级别时,通常需要能够在AEM中查看和编辑SPA。 RemotePage组件只是用于此目的的自定义页面组件。

概述

RemotePage组件从应用程序生成的中提取所有必需的资源 asset-manifest.json 和使用此项在AEM中呈现SPA。

  • RemotePage允许您将SPA的脚本和样式表插入AEM Page组件的正文中。
  • 虚拟前端组件允许在AEM SPA编辑器中将部分标记为可编辑。
  • 托管在不同域上的SPA可以一起在AEM中编辑。

请参阅文章 在AEM中编辑外部SPA 有关AEM中可编辑的外部SPA的更多详细信息。

要求

  • 在开发中启用CORS

  • 在页面属性中配置远程URL

  • 在AEM中渲染SPA

  • Web应用程序必须使用类似于以下内容的捆绑器资产清单,并在域根目录下公开asset-manifest.json文件,该文件在入口点属性中列出要加载的所有CSS和JS文件:

    • https://github.com/shellscape/webpack-manifest-plugin
    • https://github.com/webdeveric/webpack-assets-manifest
    • https://github.com/mugi-uno/parcel-plugin-bundle-manifest

    入口点

  • 应用程序必须能够在 <div id="root"></div> 主体元素下。 如果应用程序实例化需要不同的标记,则必须在具有的代理组件的HTL脚本中相应地调整此标记 sling:resourceSuperType="spa-project-core/components/remotepage.

限制

  • RemotePage组件希望实施提供类似于资产清单的资产清单 此处找到。 但是,RemotePage组件仅经过测试可用于React框架(和通过remote-page-next组件的Next.js),因此不支持从其他框架(如Angular)远程加载应用程序。
  • 在AEM中执行远程渲染时,在应用程序的根HTML文件中定义的内部CSS和根DOM节点上的内联CSS将不可用。

技术详细信息

与AEM SPA项目的其余部分一样,RemotePage组件是开源的。 有关RemotePage组件的完整技术详细信息, 请参阅GitHub存储库。

在此页面上