样式系统 style-system

样式系统允许模板作者在组件的内容策略中定义样式类,以便内容作者在页面上编辑组件时能够选择这些类。这些样式可以作为组件的替代可视化变量,从而使组件变得更加灵活。

使用样式系统,您无需为每种样式开发自定义组件,也无需自定义组件对话框来启用此类样式功能。样式系统允许使用更多可重用组件,可以快速轻松地调整这些组件以满足内容作者的需求,而无需进行任何 AEM 后端开发。

用例 use-case

模板作者不仅需要能够为内容作者配置组件的工作方式,还需要配置组件的多个替代可视化变量。

同样,内容作者不仅需要能够构建和布置他们的内容,还需要能够选择内容的可视呈现方式。

样式系统针对模板作者和内容作者的要求提供了统一的解决方案:

  • 模板作者可以在组件的内容策略中定义样式类。
  • 然后,内容作者在页面上编辑组件时,可以从下拉列表中选择这些类以应用相应的样式。

样式类随后会插入到组件的装饰包装器元素中,这样组件开发人员除了提供 CSS 规则之外,便无需关注样式的处理。

概述 overview

通常,可通过以下形式来使用样式系统。

  1. Web 设计人员创建组件的不同可视化变量。

  2. 向 HTML 开发人员提供组件的 HTML 输出以及要实施的所需可视化变量。

  3. HTML 开发人员定义与每个可视化变量对应的 CSS 类,该类将插入到组件的包装元素中。

  4. HTML 开发人员为每个可视化变量实施相应的 CSS 代码(和可选 JS 代码),以使它们按照定义的方式显示。

  5. AEM 开发人员将提供的 CSS(和可选 JS)放置在客户端库中并对其进行部署。

  6. AEM 开发人员或模板作者配置页面模板并编辑每个已设置样式的组件的策略,从而添加定义的 CSS 类、为每种样式提供用户友好名称,并指示可组合的样式。

  7. 之后,AEM 页面作者可以在页面编辑器中通过组件工具栏的样式菜单选择设计的样式。

请注意,实际上只有最后三个步骤在 AEM 中执行。这意味着,必需的 CSS 和 JavaScript 的所有开发工作都可以在没有 AEM 的情况下完成。

实际上,要实施这些样式,只需在 AEM 上部署并在所需模板的组件中进行选择即可。

下图说明了样式系统的架构。

aem-style-system

使用 use

为了演示该功能,我们将使用核心组件的标题组件WKND 实施作为示例。

下面的作为内容作者作为模板作者部分介绍了如何使用 WKND 样式系统来测试样式系统的功能。

如果您希望为自己的组件使用样式系统,请执行以下操作:

  1. 按照概述部分中的所述,将 CSS 作为客户端库进行安装。
  2. 按照作为模板作者部分中的所述,配置您要向内容作者提供的 CSS 类。
  3. 然后,内容作者可以按照作为内容作者部分中的所述使用样式。

作为内容作者 as-a-content-author

  1. 安装 WKND 项目后,导航到 WKND 的英语母版主页 http://<host>:<port>/sites.html/content/wknd/language-masters/en,然后编辑该页面。

  2. 选择该页面下方的​ 标题 ​组件

    作者的样式系统

  3. 单击​ 列表 ​组件工具栏上的​ 样式 ​按钮以打开样式菜单并更改该组件的外观。

    选择样式

    note note
    NOTE
    在此示例中,颜色 ​样式(黑色白色 ​和​ 灰色)是互斥的,而​ 样式 ​选项(下划线右对齐 ​和​ 最小间距)则可以组合使用。这可以在模板中配置为模板作者

作为模板作者 as-a-template-author

  1. 编辑WKND位于http://<host>:<port>/sites.html/content/wknd/language-masters/en的英语母版主页时,通过​ 页面信息>编辑模板 ​编辑该页面的模板。

    编辑模板

  2. 通过点按或单击​ 标题 ​组件的​ 策略 ​按钮,编辑该组件的策略。

    编辑策略

  3. 在属性的“样式”选项卡中,您可以看到样式的配置方式。

    编辑属性

    • 组名称: ​样式可以在样式菜单中分组到一起,内容作者在配置组件样式时将看到该样式菜单。
    • 样式可以合并: ​允许一次选择该组中的多个样式。
    • 样式名称: ​在配置组件样式时将向内容作者显示的样式描述。
    • CSS 类: ​与样式关联的 CSS 类的实际名称。

    使用拖动手柄可调整组以及组中样式的顺序。使用添加或删除图标可添加或者删除组或组中的样式。

CAUTION
配置为组件策略的样式属性的CSS类(以及任何必需的JavaScript)必须部署为客户端库才能正常工作。

设置 setup

核心组件版本 2 及更高版本完全支持使用样式系统,并且无需进行额外配置。

只有为您自己的自定义组件启用样式系统,或者在“编辑”对话框中启用可选的“样式”选项卡时,才需执行以下步骤。

在“设计”对话框中启用“样式”选项卡 enable-styles-tab-design

为了使组件能够与 AEM 的样式系统结合使用并在其“设计”对话框中显示“样式”选项卡,组件开发人员必须通过对组件进行以下设置来包含“样式”选项卡:

  • path = "/mnt/overlay/cq/gui/components/authoring/dialog/style/tab_design/styletab"
  • sling:resourceType = "granite/ui/components/coral/foundation/include"

配置好组件后,AEM会自动将页面作者配置的样式插入修饰元素上,AEM会自动将该修饰元素包装在每个可编辑的组件周围。 组件本身无需执行任何其他操作即可实现这一点。

在“编辑”对话框中启用“样式”选项卡 enable-styles-tab-edit

自AEM版本6.5.3.0起,“编辑”对话框中的可选“样式”选项卡现在可用。 与“设计”对话框选项卡不同,“编辑”对话框中的选项卡对于样式系统的正常运行来说并不是必需的,但它是内容作者设置样式的可选替代界面。

可以采用与“设计”对话框选项卡类似的方式包括“编辑”对话框选项卡:

  • path = "/mnt/overlay/cq/gui/components/authoring/dialog/style/tab_edit/styletab"
  • sling:resourceType = "granite/ui/components/coral/foundation/include"
NOTE
默认情况下,“编辑”对话框中的“样式”选项卡处于未启用状态。

具有元素名称的样式 styles-with-element-names

开发人员还可以使用 cq:styleElements 字符串数组属性为组件上的样式配置允许的元素名称列表。然后,在设计对话框内策略的“样式”选项卡中,模板作者也可以为每个样式选择一个要设置的元素名称。这将设置包装器元素的元素名称。

此属性在 cq:Component 节点上设置。例如:

  • /apps/<yoursite>/components/content/list@cq:styleElements=[div,section,span]
CAUTION
避免为可以合并的样式定义元素名称。当定义多个元素名称时,其优先级顺序为:
  1. HTL 优先于所有内容:data-sly-resource="${'path/to/resource' @ decorationTagName='span'}
  2. 然后,在多个活动样式中,会采用组件策略中配置的样式列表中的第一个样式。
  3. 最后,组件的 cq:htmlTag/cq:tagName 将被视为回退值。

这种定义样式名称的功能对于极其通用的组件(如布局容器或内容片段组件)非常有用,可为它们提供额外的含义。

例如,它允许为布局容器提供<main><aside><nav>等语义。

recommendation-more-help
19ffd973-7af2-44d0-84b5-d547b0dffee2