样式系统 style-system
样式系统允许模板作者在组件的内容策略中定义样式类,以便内容作者在页面上编辑组件时能够选择这些类。这些样式可以作为组件的替代可视化变量,从而使组件变得更加灵活。
使用样式系统,您无需为每种样式开发自定义组件,也无需自定义组件对话框来启用此类样式功能。样式系统允许使用更多可重用组件,可以快速轻松地调整这些组件以满足内容作者的需求,而无需进行任何 AEM 后端开发。
用例 use-case
模板作者不仅需要能够为内容作者配置组件的工作方式,还需要配置组件的多个替代可视化变量。
同样,内容作者不仅需要能够构建和布置他们的内容,还需要能够选择内容的可视呈现方式。
样式系统针对模板作者和内容作者的要求提供了统一的解决方案:
- 模板作者可以在组件的内容策略中定义样式类。
- 之后,内容作者在页面上编辑组件时,可以从下拉列表中选择这些类,以便应用相应的样式。
样式类随后会插入到组件的装饰包装器元素中,这样组件开发人员除了提供 CSS 规则之外,便无需关注样式的处理。
概述 overview
通常,可通过以下形式来使用样式系统。
-
Web 设计人员创建组件的不同可视化变量。
-
向 HTML 开发人员提供组件的 HTML 输出以及要实施的所需可视化变量。
-
HTML 开发人员定义与每个可视化变量对应的 CSS 类,该类将插入到组件的包装元素中。
-
HTML 开发人员为每个可视化变量实施相应的 CSS 代码(和可选 JS 代码),以使它们按照定义的方式显示。
-
AEM 开发人员将提供的 CSS(和可选 JS)放置在客户端库中并对其进行部署。
-
AEM 开发人员或模板作者配置页面模板并编辑每个已设置样式的组件的策略,从而添加定义的 CSS 类、为每种样式提供用户友好名称,并指示可组合的样式。
-
之后,AEM 页面作者可以在页面编辑器中通过组件工具栏的样式菜单选择设计的样式。
在AEM中实际执行的只有最后三个步骤。 这意味着,必需的 CSS 和 JavaScript 的所有开发工作都可以在没有 AEM 的情况下完成。
实际上,要实施这些样式,只需在 AEM 上部署并在所需模板的组件中进行选择即可。
下图说明了样式系统的架构。
使用 use
为了演示该功能,我们将使用核心组件的标题组件的 WKND 实施作为示例。
下面的作为内容作者和作为模板作者部分介绍了如何使用 WKND 样式系统来测试样式系统的功能。
如果要为自己的组件使用样式系统,请执行以下操作:
作为内容作者 as-a-content-author
-
安装 WKND 项目后,导航到 WKND 的英语母版主页
http://<host>:<port>/sites.html/content/wknd/language-masters/en
,然后编辑该页面。 -
选择该页面下方的 标题 组件
-
选择 样式 工具栏上的按钮 列表 组件打开样式菜单并更改组件的外观。
note note NOTE 在此示例中,颜色 样式(黑色、白色 和 灰色)是互斥的,而 样式 选项(下划线、右对齐 和 最小间距)则可以组合使用。这可以在模板中配置为模板作者。
作为模板作者 as-a-template-author
-
编辑WKND的英语母版主页时
http://<host>:<port>/sites.html/content/wknd/language-masters/en
,通过编辑页面的模板 “页面信息”>“编辑模板”. -
通过点按或单击 标题 组件的 策略 按钮,编辑该组件的策略。
-
在属性的“样式”选项卡中,您可以看到样式的配置方式。
- 组名称: 样式可以在样式菜单中分为一组,内容作者在配置组件样式时会看到该样式菜单。
- 样式可以合并: 允许一次选择该组中的多个样式。
- 样式名称: 在配置组件样式时将向内容作者显示的样式描述。
- CSS 类: 与样式关联的 CSS 类的实际名称。
使用拖动手柄可调整组以及组中样式的顺序。使用添加或删除图标可添加或者删除组或组中的样式。
设置 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
“编辑”对话框中的可选“样式”选项卡也可以使用。与“设计”对话框选项卡不同,“编辑”对话框中的选项卡对于样式系统的正常运行来说并不是必需的,但它是内容作者设置样式的可选替代界面。
可以采用与“设计”对话框选项卡类似的方式包括“编辑”对话框选项卡:
path = "/mnt/overlay/cq/gui/components/authoring/dialog/style/tab_edit/styletab"
sling:resourceType = "granite/ui/components/coral/foundation/include"
具有元素名称的样式 styles-with-element-names
开发人员还可以使用 cq:styleElements
字符串数组属性为组件上的样式配置允许的元素名称列表。然后,在设计对话框内策略的“样式”选项卡中,模板作者也可以为每个样式选择一个要设置的元素名称。这将设置包装器元素的元素名称。
此属性在 cq:Component
节点上设置。例如:
/apps/<yoursite>/components/content/list@cq:styleElements=[div,section,span]
- HTL 优先于所有内容:
data-sly-resource="${'path/to/resource' @ decorationTagName='span'}
- 然后,在多个活动样式中,会采用组件策略中配置的样式列表中的第一个样式。
- 最后,组件的
cq:htmlTag
/cq:tagName
会被视为回退值。
这种定义样式名称的功能对于通用的组件(如布局容器或内容片段组件)非常有用,可为它们提供更多含义。
例如,它允许为布局容器提供如下语义 <main>
, <aside>
, <nav>
,等等。