使用客户端库 using-client-side-libraries

CAUTION
AEM 6.4已结束扩展支持,本文档将不再更新。 有关更多详细信息,请参阅 技术支助期. 查找支持的版本 此处.

现代网站严重依赖由复杂的JavaScript和CSS代码驱动的客户端处理。 组织和优化此代码的服务可能是一个复杂的问题。

为帮助处理此问题,AEM提供 客户端库文件夹,用于在存储库中存储客户端代码,将其组织为各个类别,并定义何时以及如何将每个类别的代码提供给客户端。 然后,客户端库系统会负责在最终网页中生成正确的链接,以加载正确的代码。

客户端库在AEM中的工作原理 how-client-side-libraries-work-in-aem

在页面HTML中包含客户端库(即JS或CSS文件)的标准方式是,只需在 <script><link> 标记,其中包含相关文件的路径。 例如,

...
<head>
   ...
   <script type="text/javascript" src="/etc/clientlibs/granite/jquery/source/1.8.1/jquery-1.8.1.js"></script>
   ...
</head>
...

虽然此方法在AEM中有效,但在页面及其组成组件变得复杂时,可能会导致问题。 在这种情况下,同一JS库的多个副本可能会包含在最终HTML输出中。 要避免这种情况,并允许对AEM使用的客户端库进行逻辑组织 客户端库文件夹.

客户端库文件夹是类型的存储库节点 cq:ClientLibraryFolder. 这是 CND符号 is

[cq:ClientLibraryFolder] > sling:Folder
  - dependencies (string) multiple
  - categories (string) multiple
  - embed (string) multiple
  - channels (string) multiple

默认情况下, cq:ClientLibraryFolder 节点可置于 /apps, /libs/etc 存储库的子树(这些默认值和其他设置可通过 AdobeGraniteHTML库管理器 面板 系统控制台)。

每个 cq:ClientLibraryFolder 中填充了一组JS和/或CSS文件,以及一些支持文件(请参阅下文)。 的属性 cq:ClientLibraryFolder 配置如下:

  • categories:标识此文件中JS和/或CSS文件集所属的类别 cq:ClientLibraryFolder 摔倒。 的 categories 属性具有多值,允许库文件夹包含在多个类别中(请参阅下文,了解这种属性的用法)。

  • dependencies:这是此库文件夹所依赖的其他客户端库类别的列表。 例如,给定两个 cq:ClientLibraryFolder 节点 FG,如果文件位于 F 需要另一个文件 G 为了正常运行, categories of G 应该属于 dependencies of F.

  • embed:用于嵌入来自其他库的代码。 如果节点F嵌入节点G和H,则生成的HTML将是来自节点G和H的内容集中。

  • allowProxy:如果客户端库位于 /apps,此属性允许通过代理servlet访问该变量。 请参阅 查找客户端库文件夹并使用代理客户端库Servlet 下。

引用客户端库 referencing-client-side-libraries

由于HTL是开发AEM站点的首选技术,因此应使用HTL在AEM中包含客户端库。 但是,也可以使用JSP来执行此操作。

使用HTL using-htl

在HTL中,客户端库通过AEM提供的帮助程序模板加载,该模板可通过 data-sly-use. 此文件中提供了三个模板,可通过 data-sly-call:

  • css — 仅加载引用的客户端库的CSS文件。
  • js — 仅加载引用的客户端库的JavaScript文件。
  • 全部 — 加载引用的客户端库的所有文件(CSS和JavaScript)。

每个帮助程序模板都需要一个 categories 选项来引用所需的客户端库。该选项可以是字符串值的数组,也可以是包含逗号分隔值列表的字符串。

有关使用的更多详细信息和示例,请参阅此文档 HTML模板语言快速入门.

使用JSP using-jsp

添加 ui:includeClientLib 标记到您的JSP代码,以在生成的HTML页中添加到客户端库的链接。 要引用库,请使用 categories 属性 ui:includeClientLib 节点。

<%@taglib prefix="ui" uri="https://www.adobe.com/taglibs/granite/ui/1.0" %>
<ui:includeClientLib categories="<%= categories %>" />

例如, /etc/clientlibs/foundation/jquery 节点类型 cq:ClientLibraryFolder 具有值的类别属性 cq.jquery. JSP文件中的以下代码引用了库:

<ui:includeClientLib categories="cq.jquery"/>

生成的HTML页面包含以下代码:

<script type="text/javascript" src="/etc/clientlibs/foundation/jquery.js"></script>

有关完整信息(包括用于筛选JS、CSS或主题库的属性),请参阅 ui:includeClientLib.

CAUTION
<cq:includeClientLib>自AEM 5.6以来,已弃用该函数,过去常用于包含客户端库。 <ui:includeClientLib> 应使用,如上所述。

创建客户端库文件夹 creating-client-library-folders

创建 cq:ClientLibraryFolder 节点来定义JavaScript和层叠样式表库,并使它们可用于HTML页面。 使用 categories 节点的属性,以标识它所属的库类别。

节点包含一个或多个在运行时合并到单个JS和/或CSS文件中的源文件。 生成的文件的名称是节点名称,其中节点名称的 .js.css 文件扩展名。 例如,名为的库节点 cq.jquery 结果生成的文件名为 cq.jquery.jscq.jquery.css.

客户端库文件夹包含以下项目:

  • 要合并的JS和/或CSS源文件。

  • 支持CSS样式的资源,如图像文件。

    注意: 您可以使用子文件夹来组织源文件。

  • 一个 js.txt 文件和/或一个 css.txt 用于标识要合并到生成的JS和/或CSS文件中的源文件的文件。

clientlibarch

有关特定于小组件的客户端库的要求的信息,请参阅 使用和扩展小组件.

Web客户端必须具有访问 cq:ClientLibraryFolder 节点。 您还可以从存储库的安全区域中显示库(请参阅下面的“从其他库嵌入代码”)。

覆盖/lib中的库 overriding-libraries-in-lib

位于下方的客户端库文件夹 /apps 优先于位于中相似位置的同名文件夹 /libs. 例如, /apps/cq/ui/widgets 优先于 /libs/cq/ui/widgets. 当这些库属于同一类别时,以下库 /apps 中,将使用。

查找客户端库文件夹并使用代理客户端库Servlet locating-a-client-library-folder-and-using-the-proxy-client-libraries-servlet

在以前的版本中,客户端库文件夹位于以下位置 /etc/clientlibs 中。 此功能仍受支持,但建议客户端库现在位于 /apps. 这是为了在其他脚本附近找到客户端库,这些脚本通常在下面找到 /apps/libs.

NOTE
客户端库文件夹下的静态资源必须位于名为 资源. 如果文件夹下没有静态资源(如图像) 资源,则无法在发布实例上引用它。 示例如下:http://localhost:4503/etc.clientlibs/geometrixx/components/clientlibs/resources/example.gif
NOTE
为了更好地将代码与内容和配置隔离,建议在 /apps 通过 /etc.clientlibs 通过利用 allowProxy 属性。

为了在 /apps 若要访问,请使用代理服务器。 ACL仍对客户端库文件夹强制执行,但Servlet允许通过读取内容 /etc.clientlibs/ 如果 allowProxy 属性设置为 true.

如果静态资源位于客户端库文件夹下的资源下,则只能通过代理访问该静态资源。

例如:

  • 您的 /apps/myproject/clientlibs/foo
  • 您的 /apps/myprojects/clientlibs/foo/resources/icon.png

然后,您将 allowProxy 属性 foo 为真。

  • 然后,您可以请求 /etc.clientlibs/myprojects/clientlibs/foo.js
  • 然后,您可以通过 /etc.clientlibs/myprojects/clientlibs/foo/resources/icon.png
CAUTION
使用代理客户端库时,AEM Dispatcher配置可能需要更新,以确保允许具有扩展clientlibs的URI。
CAUTION
Adobe建议在 /apps 并使用代理servlet提供。 但请记住,最佳做法仍要求公共站点不得包含通过 /apps/libs 路径。

创建客户端库文件夹 create-a-client-library-folder

  1. 在Web浏览器中打开CRXDE Lite(http://localhost:4502/crx/de)。

  2. 选择要在其中找到客户端库文件夹的文件夹,然后单击 创建>创建节点.

  3. 输入库文件的名称,然后在类型列表中选择 cq:ClientLibraryFolder. 单击 确定 然后单击 全部保存.

  4. 要指定库所属的类别或类别,请选择 cq:ClientLibraryFolder 节点中,添加以下属性,然后单击 全部保存:

    • 名称:类别
    • 类型:字符串
    • 值:类别名称
    • 多:选择
  5. 通过任何方式将源文件添加到库文件夹。 例如,使用WebDav客户端复制文件,或创建文件并手动创作内容。

    注意: 您可以根据需要将源文件组织在子文件夹中。

  6. 选择客户端库文件夹,然后单击 创建>创建文件.

  7. 在文件名框中,键入以下文件名之一,然后单击“确定”:

    • js.txt: 使用此文件名生成JavaScript文件。
    • css.txt: 使用此文件名生成层叠样式表。
  8. 打开文件并键入以下文本以标识源文件路径的根:

    #base=[root]

    替换 [root] 包含源文件的文件夹路径(相对于TXT文件)。 例如,当源文件与TXT文件位于同一文件夹时,请使用以下文本:

    #base=.

    以下代码会将根目录设置为 cq:ClientLibraryFolder 节点:

    #base=mobile

  9. 在以下行中 #base=[root],键入源文件相对于根的路径。 将每个文件名放在单独的行上。

  10. 单击 全部保存.

链接到依赖项 linking-to-dependencies

当客户端库文件夹中的代码引用其他库时,请将其他库标识为依赖项。 在JSP中, ui:includeClientLib 引用客户端库文件夹的标记会导致HTML代码包含指向您生成的库文件的链接以及依赖关系。

依赖项必须是另一个 cq:ClientLibraryFolder. 要识别依赖项,请向 cq:ClientLibraryFolder 具有以下属性的节点:

  • 名称: 依赖
  • 类型: 字符串[]
  • 值: 当前库文件夹所依赖的cq:ClientLibraryFolder节点的categories属性的值。

例如,/ etc/clientlibs/myclientlibs/publicmaincq.jquery 库。 引用主客户端库的JSP会生成包含以下代码的HTML:

<script src="/etc/clientlibs/foundation/cq.jquery.js" type="text/javascript">
<script src="/etc/clientlibs/mylibs/publicmain.js" type="text/javascript">

从其他库嵌入代码 embedding-code-from-other-libraries

您可以将来自客户端库的代码嵌入到其他客户端库中。 在运行时,嵌入库生成的JS和CSS文件包含嵌入库的代码。

嵌入代码对于提供对存储在存储库安全区域中的库的访问权限非常有用。

特定于应用程序的客户端库文件夹 app-specific-client-library-folders

最佳做法是将所有与应用程序相关的文件保留在其应用程序文件夹下 /app. 此外,最好还是拒绝网站访客访问 /app 文件夹。 要满足这两个最佳实践,请在 /etc 嵌入下面客户端库的文件夹 /app.

使用类别属性标识要嵌入的客户端库文件夹。 要嵌入库,请向嵌入中添加资产 cq:ClientLibraryFolder 节点,使用以下属性属性:

  • 名称: 嵌入
  • 类型: 字符串[]
  • 值: 的类别属性的值 cq:ClientLibraryFolder 要嵌入的节点。

使用嵌入最小化请求 using-embedding-to-minimize-requests

在某些情况下,您可能会发现,由发布实例为典型页面生成的最终HTML包含的页面数量相对较多 <script> 元素,特别是当您的网站正在将客户端上下文信息用于Analytics或定位时。 例如,在非优化项目中,您可能会找到以下系列 <script> 页面HTML中的元素:

<script type="text/javascript" src="/etc/clientlibs/granite/jquery.js"></script>
<script type="text/javascript" src="/etc/clientlibs/granite/utils.js"></script>
<script type="text/javascript" src="/etc/clientlibs/granite/jquery/granite.js"></script>
<script type="text/javascript" src="/etc/clientlibs/foundation/jquery.js"></script>
<script type="text/javascript" src="/etc/clientlibs/foundation/shared.js"></script>
<script type="text/javascript" src="/etc/clientlibs/foundation/personalization/kernel.js"></script>

在这种情况下,将所有必需的客户端库代码合并到单个文件中,以减少页面加载时来回请求的数量,这非常有用。 为此,您可以 embed 使用的embed属性将所需的库放入特定于应用程序的客户端库中 cq:ClientLibraryFolder 节点。

AEM中包含以下客户端库类别。 您应仅嵌入特定网站运行所需的内容。 但是, 您应维护此处列出的顺序:

  1. browsermap.standard
  2. browsermap
  3. jquery-ui
  4. cq.jquery.ui
  5. personalization
  6. personalization.core
  7. personalization.core.kernel
  8. personalization.clientcontext.kernel
  9. personalization.stores.kernel
  10. personalization.kernel
  11. personalization.clientcontext
  12. personalization.stores
  13. cq.collab.comments
  14. cq.collab.feedlink
  15. cq.collab.ratings
  16. cq.collab.toggle
  17. cq.collab.forum
  18. cq.cleditor

CSS文件中的路径 paths-in-css-files

嵌入CSS文件时,生成的CSS代码会使用指向与嵌入库相关的资源的路径。 例如,可公开访问的库 /etc/client/libraries/myclientlibs/publicmain 嵌入 /apps/myapp/clientlib 客户端库:

screen_shot_2012-05-29at20122pm

main.css 文件包含以下样式:

body {
  padding: 0;
  margin: 0;
  background: url(images/bg-full.jpg) no-repeat center top;
  width: 100%;
}

用于 publicmain 节点使用原始图像的URL生成包含以下样式:

body {
  padding: 0;
  margin: 0;
  background: url(../../../apps/myapp/clientlib/styles/images/bg-full.jpg) no-repeat center top;
  width: 100%;
}

为特定移动组使用库 using-a-library-for-specific-mobile-groups

使用 channels 客户端库文件夹的属性,用于标识使用库的移动设备组。 的 channels 当针对不同设备功能设计了同一类别的库时,该属性非常有用。

要将客户端库文件夹与设备组关联,请向 cq:ClientLibraryFolder 具有以下属性的节点:

  • 名称: 渠道
  • 类型: 字符串[]
  • 值: 移动组的名称。 要从组中排除库文件夹,请在名称前添加感叹号(“!”)。

例如,下表列出了 channels 属性 cq.widgets 类别:

客户端库文件夹
渠道属性的值
/libs/cq/analytics/widgets
!touch
/libs/cq/analytics/widgets/themes/default
!touch
/libs/cq/cloudserviceconfigs/widgets
!touch
/libs/cq/touch/widgets
touch
/libs/cq/touch/widgets/themes/default
touch
/libs/cq/ui/widgets
!touch
/libs/cq/ui/widgets/themes/default
!touch

使用预处理器 using-preprocessors

AEM允许可插拔的预处理器,并支持 YUI压缩机 (对于CSS和JavaScript)和 Google关闭编译器(GCC) (对于将YUI设置为AEM默认预处理器的JavaScript)。

可插拔预处理器允许灵活使用,包括:

  • 定义可处理脚本源的ScriptProcessors
  • 处理器可通过选项进行配置
  • 处理器可用于缩小,但也可用于未缩小的情况
  • clientlib可定义要使用的处理器
NOTE
默认情况下,AEM使用YUI压缩程序。 请参阅 YUI压缩程序GitHub文档 列出已知问题。 在使用YUI时,切换到特定客户端的GCC压缩程序可能会解决一些观察到的问题。
CAUTION
请勿在客户端库中放置缩小的库。 请改为提供原始库,如果需要缩小,请使用预处理器的选项。

用途 usage

您可以选择为每个客户端库或系统范围配置预处理器配置。

  • 添加多值属性 cssProcessorjsProcessor 在clientlibrary节点上

  • 或通过 HTML库管理器 OSGi配置

clientlib节点上的预处理器配置优先于OSGI配置。

格式和示例 format-and-examples

格式 format

config:= mode ":" processorName options*;
mode:= "default" | "min";
processorName := "none" | <name>;
options := ";" option;
option := name "=" value;

用于CSS缩小的YUI压缩程序和用于JS的GCC压缩程序 yui-compressor-for-css-minification-and-gcc-for-js

cssProcessor: ["default:none", "min:yui"]
jsProcessor: ["default:none", "min:gcc;compilationLevel=advanced"]

对GCC进行预处理,然后对GCC进行缩小和模糊处理 typescript-to-preprocess-and-then-gcc-to-minify-and-obfuscate

jsProcessor: [
   "default:typescript",
   "min:typescript",
   "min:gcc;obfuscate=true"
]

其他GCC选项 additional-gcc-options

failOnWarning (defaults to "false")
languageIn (defaults to "ECMASCRIPT5")
languageOut (defaults to "ECMASCRIPT5")
compilationLevel (defaults to "simple") (can be "whitespace", "simple", "advanced")

有关GCC选项的更多详细信息,请参阅 GCC文档.

设置系统默认缩小器 set-system-default-minifier

在AEM中,YUI设置为默认的缩小符。 要将此代码更改为GCC,请执行以下步骤。

  1. 转到Apache Felix配置管理器(位于 http://localhost:4502/system/console/configMgr

  2. 查找和编辑 AdobeGraniteHTML库管理器.

  3. 启用 缩小 选项(如果尚未启用)。

  4. 设置值 JS处理器默认配置 to min:gcc.

    如果使用分号(例如, min:gcc;obfuscate=true.

  5. 单击 保存 以保存更改。

调试工具 debugging-tools

AEM提供了多种工具来调试和测试客户端库文件夹。

请参阅嵌入的文件 see-embedded-files

要跟踪嵌入代码的源,或确保嵌入的客户端库生成预期结果,您可以在运行时查看正在嵌入的文件的名称。 要查看文件名,请在 debugClientLibs=true 参数。 生成的库包含 @import 语句,而不是嵌入代码。

在上一个示例中 从其他库嵌入代码 , /etc/client/libraries/myclientlibs/publicmain 客户端库文件夹嵌入了 /apps/myapp/clientlib 客户端库文件夹。 将参数附加到网页后,会在网页的源代码中生成以下链接:

<link rel="stylesheet" href="/etc/clientlibs/mycientlibs/publicmain.css">

打开 publicmain.css 文件会显示以下代码:

@import url("/apps/myapp/clientlib/styles/main.css");
  1. 在Web浏览器的地址框中,将以下文本附加到HTML的URL:

    ?debugClientLibs=true

  2. 页面加载时,查看页面源。

  3. 单击作为链接元素的href提供的链接以打开文件并查看源代码。

发现客户端库 discover-client-libraries

/libs/cq/granite/components/dumplibs/dumplibs 组件会生成有关系统上所有客户端库文件夹的信息页面。 的 /libs/granite/ui/content/dumplibs 节点将组件作为资源类型。 要打开页面,请使用以下URL(根据需要更改主机和端口):

https://<host>:<port>/libs/granite/ui/content/dumplibs.test.html

该信息包括库路径和类型(CSS或JS),以及库属性的值,如类别和依赖关系。 页面上的后续表显示了每个类别和渠道中的库。

请参阅生成的输出 see-generated-output

dumplibs 组件包含测试选择器,该测试选择器显示为 ui:includeClientLib 标记。 页面包含js、css和主题属性的不同组合的代码。

  1. 使用以下方法之一打开“测试输出”页:

    • dumplibs.html 页面上的 单击此处进行输出测试 文本。

    • 在Web浏览器中打开以下URL(根据需要使用其他主机和端口):

      • http://<host>:<port>/libs/granite/ui/content/dumplibs.html

    默认页面显示类别属性没有值的标记的输出。

  2. 要查看类别的输出,请键入客户端库的 categories 属性并单击 提交查询.

为开发和生产配置库处理 configuring-library-handling-for-development-and-production

HTML库管理器服务流程 cq:ClientLibraryFolder 标记,并在运行时生成库。 环境类型、开发或生产类型决定了应如何配置服务:

  • 提高安全性:禁用调试
  • 提高性能:删除空格并压缩库。
  • 提高可读性:包括空格和不压缩。

有关配置服务的信息,请参阅 AEMHTML库管理器.

recommendation-more-help
2315f3f5-cb4a-4530-9999-30c8319c520e