样式AEM CIF核心组件 style-aem-cif-core-components

CIF Venia项目 是一个参考代码库,用于 CIF核心组件. 在本教程中,您将检查Venia参考项目并了解AEM CIF核心组件使用的CSS和JavaScript的组织方式。 还可以使用CSS创建样式,以更新 产品Teaser 组件。

TIP
使用 AEM项目原型 开始您自己的commerce实施时。

您将构建的内容

在本教程中,将实施产品Teaser组件的新样式,该样式类似于信息卡。 在本教程中吸取的经验教训可以应用于其他CIF核心组件。

您将构建的内容

先决条件 prerequisites

需要本地开发环境才能完成本教程。 此环境包括一个正在运行的AEM实例,该实例已配置并连接到Adobe Commerce实例。 查看的要求和步骤 使用AEMas a Cloud ServiceSDK设置本地开发.

克隆Venia项目 clone-venia-project

您即将克隆 Venia项目,然后覆盖默认样式。

NOTE
您可以随意使用现有项目 (基于包含CIF的AEM项目原型)并跳过此部分。
  1. 运行以下git命令,以便克隆项目:

    code language-shell
    $ git clone git@github.com:adobe/aem-cif-guides-venia.git
    
  2. 生成项目并将其部署到AEM的本地实例:

    code language-shell
    $ cd aem-cif-guides-venia/
    $ mvn clean install -PautoInstallPackage,cloud
    
  3. 添加必要的OSGi配置,以便将AEM实例连接到Adobe Commerce实例,或将配置添加到创建的项目。

  4. 此时,您应该拥有连接到Adobe Commerce实例的工作中店面版本。 导航至 US > Home 页面位置: http://localhost:4502/editor.html/content/venia/us/en.html.

    您应该会看到店面当前使用的是Venia主题。 展开店面的主菜单,您应该会看到各种类别,这表示与Adobe Commerce的连接正在正常工作。

    用Venia主题配置的店面

客户端库和ui.frontend模块 introduction-to-client-libraries

在AEM中,负责呈现店面主题/样式的CSS和JavaScript由管理 客户端库 或“clientlibs”的简称。 客户端库提供了一种机制,可在项目代码中整理CSS和JavaScript,然后交付到页面上。

通过添加和覆盖这些客户端库管理的CSS,可以将特定于品牌的样式应用于AEM CIF核心组件。 了解如何构建客户端库并将其包含在页面上至关重要。

ui.frontend 是专门的 webpack 用于管理项目的所有前端资产的项目。 此Webpack允许前端开发人员使用任意数量的语言和技术,如 TypeScript萨斯,等等。

ui.frontend 模块还是一个Maven模块,通过使用NPM模块与更大的项目集成 aem-clientlib-generator. 在构建期间, aem-clientlib-generator 将编译后的CSS和JavaScript文件复制到的 ui.apps 模块。

ui.frontend到ui.apps架构

编译的CSS和JavaScript会从 ui.frontend 将模块移入 ui.apps 在Maven构建期间用作客户端库的模块

更新Teaser样式 ui-frontend-module

接下来,对Teaser样式进行细微更改,以了解 ui.frontend 模块和客户端库均起作用。 使用 您选择的IDE 以导入Venia项目。 使用的屏幕截图来自 Visual Studio Code IDE.

  1. 导航并展开 ui.frontend 模块并将文件夹层次结构展开到: ui.frontend/src/main/styles/commerce

    ui.frontend商业文件夹

    请注意,存在多个Sass (.scss)文件。 这些文件是每个Commerce组件的Commerce特定样式。

  2. 打开文件 _productteaser.scss.

  3. 更新 .item__image 规则并修改边框规则:

    code language-scss
    .item__image {
        border: #ea00ff 8px solid; /* <-- modify this rule */
        display: block;
        grid-area: main;
        height: auto;
        opacity: 1;
        transition-duration: 512ms;
        transition-property: opacity, visibility;
        transition-timing-function: ease-out;
        visibility: visible;
        width: 100%;
    }
    

    上述规则应该为产品Teaser组件添加粗粉红色边框。

  4. 打开新的终端窗口并导航到 ui.frontend 文件夹:

    code language-shell
    $ cd <project-location>/aem-cif-guides-venia/ui.frontend
    
  5. 运行以下Maven命令:

    code language-shell
    $ mvn clean install
    ...
    [INFO] ------------------------------------------------------------------------
    [INFO] BUILD SUCCESS
    [INFO] ------------------------------------------------------------------------
    [INFO] Total time:  29.497 s
    [INFO] Finished at: 2020-08-25T14:30:44-07:00
    [INFO] ------------------------------------------------------------------------
    

    Inspect终端输出。 请注意,Maven命令运行了多个NPM脚本,包括 npm run build. 此 npm run build 命令定义于 package.json 文件并编译webpack项目并触发客户端库生成。

  6. Inspect文件 ui.frontend/dist/clientlib-site/site.css

    已编译的站点CSS

    该文件是项目中所有Sass文件的编译和缩小版本。

    note note
    NOTE
    此类文件会从源代码管理中忽略,因为它们应在构建期间生成。
  7. Inspect文件 ui.frontend/clientlib.config.js.

    code language-js
    /* clientlib.config.js*/
    ...
    // Config for `aem-clientlib-generator`
    module.exports = {
        context: BUILD_DIR,
        clientLibRoot: CLIENTLIB_DIR,
        libs: [
            {
                ...libsBaseConfig,
                name: 'clientlib-site',
                categories: ['venia.site'],
                dependencies: ['venia.dependencies', 'aem-core-cif-react-components'],
                assets: {
    ...
    

    此配置文件用于 aem-clientlib-generator 和确定将编译后的CSS和JavaScript转换为AEM客户端库的位置和方式。

  8. ui.apps 模块,检查文件: ui.apps/src/main/content/jcr_root/apps/venia/clientlibs/clientlib-site/css/site.css

    ui.apps中已编译站点CSS

    此文件为 site.css 已复制到 ui.apps 项目。 它现在包含在名为的客户端库中 clientlib-site 具有类别 venia.site. 一旦文件成为 ui.apps 模块,可将其部署到AEM。

    note note
    NOTE
    类似这样的文件也会从源代码管理中忽略,因为它们应该在构建期间生成。
  9. 接下来,检查项目生成的其他客户端库:

    其他客户端库

    这些客户端库不受 ui.frontend 模块。 这些客户端库包含由Adobe提供的CSS和JavaScript依赖项。 这些客户端库的定义位于 .content.xml 每个文件夹下的文件。

    clientlib-base — 一个空的客户端库,其中仅嵌入来自的必需依赖项 AEM核心组件. 类别为 venia.base.

    clientlib-cif — 一个空的客户端库,其中仅嵌入来自的必需依赖项 AEM CIF核心组件. 类别为 venia.cif.

    clientlib-grid — 包括用于启用AEM响应式网格功能的CSS。 使用AEM网格可启用 布局模式 AEM并赋予内容作者调整组件大小的功能。 类别为 venia.grid 并嵌入在 venia.base 库。

  10. Inspect文件 customheaderlibs.htmlcustomfooterlibs.htmlui.apps/src/main/content/jcr_root/apps/venia/components/page

    自定义页眉和页脚脚本

    这些脚本包括 venia.basevenia.cif 库作为所有页面的一部分。

    note note
    NOTE
    在页面脚本中,只有基础库进行“硬编码”。 venia.site 不会包含在这些文件中,而是作为页面模板的一部分包含,这样可以更加灵活。 稍后将检查此流程。
  11. 从终端,构建整个项目并将其部署到AEM的本地实例:

    code language-shell
    $ cd aem-cif-guides-venia/
    $ mvn clean install -PautoInstallPackage,cloud
    

创作产品Teaser author-product-teaser

现在已部署代码更新,请使用AEM创作工具将产品Teaser组件的实例添加到网站的主页。 这样,我们就可以查看更新的样式。

  1. 打开新的浏览器选项卡,并导航至 主页 网站的: http://localhost:4502/editor.html/content/venia/us/en.html.

  2. 在中展开资产查找器(侧边栏) 编辑 模式。 将资源筛选器切换到 产品.

    展开资产查找器并按产品进行筛选

  3. 将新产品拖放到主布局容器的主页上:

    带粉红色边框的产品Teaser

    您应该会看到,根据之前创建的CSS规则更改,产品Teaser现在具有亮粉红色边框。

验证页面上的客户端库 verify-client-libraries

接下来,验证页面上是否包含客户端库。

  1. 导航至 主页 网站的: http://localhost:4502/editor.html/content/venia/us/en.html.

  2. 选择 页面信息 菜单并单击 查看已发布的项目

    查看已发布的项目

    此页面打开时不会加载任何AEM创作JavaScript,就像在发布的站点中一样。 请注意,url具有查询参数 ?wcmmode=disabled 已附加。 在开发CSS和JavaScript时,最好使用此参数来简化页面,而无需使用AEM创作中的任何内容。

  3. 查看页面源,您应该能够识别包含了多个客户端库:

    code language-html
    <!DOCTYPE html>
    <html lang="en-US">
    <head>
        ...
        <link rel="stylesheet" href="/etc.clientlibs/venia/clientlibs/clientlib-base.min.css" type="text/css">
        <link rel="stylesheet" href="/etc.clientlibs/venia/clientlibs/clientlib-site.min.css" type="text/css">
    </head>
    ...
        <script type="text/javascript" src="/etc.clientlibs/venia/clientlibs/clientlib-site.min.js"></script>
        <script type="text/javascript" src="/etc.clientlibs/core/wcm/components/commons/site/clientlibs/container.min.js"></script>
        <script type="text/javascript" src="/etc.clientlibs/venia/clientlibs/clientlib-base.min.js"></script>
    <script type="text/javascript" src="/etc.clientlibs/core/cif/clientlibs/common.min.js"></script>
    <script type="text/javascript" src="/etc.clientlibs/venia/clientlibs/clientlib-cif.min.js"></script>
    </body>
    </html>
    

    客户端库在交付到页面时带有前缀 /etc.clientlibs 并通过以下方式提供 代理 避免暴露任何敏感内容 /apps/libs.

    注意 venia/clientlibs/clientlib-site.min.cssvenia/clientlibs/clientlib-site.min.js. 这些文件是编译的CSS和JavaScript文件,这些文件派生自 ui.frontend 模块。

包含客户端库和页面模板 client-library-inclusion-pagetemplates

有几个选项可用于说明如何包含客户端库。 接下来,检查生成的项目如何包含 clientlib-site 库,通过 页面模板.

  1. 导航至 主页 在AEM编辑器中: http://localhost:4502/editor.html/content/venia/us/en.html.

  2. 选择 页面信息 菜单并单击 编辑模板

    编辑模板

    登陆页面 此时将打开模板,该模板 主页 基于的页面。

    note note
    NOTE
    要从AEM“开始”屏幕查看所有可用的模板,请导航至 工具 > 常规 > 模板.
  3. 在左上角,选择 页面信息 图标并单击 页面策略.

    页面策略菜单项

  4. 此时将为登陆页面模板打开页面策略:

    页面策略 — 登陆页面

    在右侧,您可以看到客户端库的列表 类别 包含在使用此模板的所有页面上的相同内容。

    • venia.dependencies — 提供符合以下条件的任何供应商库: venia.site 依具体情况而定。
    • venia.site — 的类别 clientlib-siteui.frontend 模块生成。

    请注意,其他模板使用相同的策略, 内容页面登陆页面,等等。 通过重用相同的策略,可以确保在所有页面上都包含相同的客户端库。

    使用模板和页面策略管理客户端库包含的好处是,您可以为每个模板更改策略。 例如,您可能在同一个AEM实例中管理两个不同的品牌。 每个品牌都有自己独特的风格或 主题 但基础库和代码是相同的。 另一个示例,如果您有一个更大的客户端库,而您只希望该库显示在某些页面上,则您可以为该模板制定唯一的页面策略。

本地Webpack开发 local-webpack-development

在上一个练习中,更新了 ui.frontend 模块,然后在执行Maven构建之后,将更改部署到AEM。 接下来,您将考虑使用webpack-dev-server来快速开发前端样式。

webpack-dev-server代理来自AEM的本地实例的图像和一些CSS/JavaScript,但允许开发人员在 ui.frontend 模块。

  1. 在浏览器中,导航到 主页 页面和 查看已发布的项目http://localhost:4502/content/venia/us/en.html?wcmmode=disabled.

  2. 查看页面源和 复制 页面的原始HTML。

  3. 返回您选择的IDE,位于 ui.frontend 模块打开文件: ui.frontend/src/main/static/index.html

    静态HTML文件

  4. 覆盖的内容 index.html粘贴 上一步中复制的HTML。

  5. 查找“include”以查找 clientlib-site.min.cssclientlib-site.min.js、和 移除 他们。

    code language-html
    <head>
        <!-- remove this link -->
        <link rel="stylesheet" href="/etc.clientlibs/venia/clientlibs/clientlib-base.min.css" type="text/css">
        ...
    </head>
    <body>
        ...
         <!-- remove this link -->
        <script type="text/javascript" src="/etc.clientlibs/venia/clientlibs/clientlib-site.min.js"></script>
    </body>
    

    这些“include”会被删除,因为它们表示由生成的CSS和JavaScript的编译版本。 ui.frontend 模块。 将其他客户端库保留为将从正在运行的AEM实例代理的客户端库。

  6. 打开新的终端窗口并导航到 ui.frontend 文件夹。 运行命令 npm start

    code language-shell
    $ cd ui.frontend
    $ npm start
    

    此命令启动webpack-dev-server http://localhost:8080/

    note caution
    CAUTION
    如果收到Sass相关错误,请停止服务器并运行命令 npm rebuild node-sass 并重复上述步骤。 如果您有其他版本的 npmnode 比在项目中指定的要多 aem-cif-guides-venia/pom.xml.
  7. 导航至 http://localhost:8080/ 在与登录的AEM实例具有相同浏览器的新选项卡中。 您应会通过webpack-dev-server看到Venia主页:

    端口80上的Webpack开发服务器

    保持webpack-dev-server正在运行。 它将在下一个练习中使用。

实施产品Teaser的卡片样式 update-css-product-teaser

接下来,修改 ui.frontend 模块,用于为Product Teaser实施类似卡片的样式。 webpack-dev-server用于快速查看更改。

返回到IDE和生成的项目。

  1. ui.frontend 模块,重新打开文件 _productteaser.scssui.frontend/src/main/styles/commerce/_productteaser.scss.

  2. 对产品Teaser边框进行以下更改:

    code language-diff
        .item__image {
    -       border: #ea00ff 8px solid;
    +       border-bottom: 1px solid #c0c0c0;
            display: block;
            grid-area: main;
            height: auto;
            opacity: 1;
            transition-duration: 512ms;
            transition-property: opacity, visibility;
            transition-timing-function: ease-out;
            visibility: visible;
            width: 100%;
        }
    

    保存更改,webpack-dev-server应使用新样式自动刷新。

  3. 在产品Teaser中添加投影并包括圆角。

    code language-scss
     .item__root {
         position: relative;
         box-shadow: 0 4px 8px 0 rgba(0,0,0,0.2);
         transition: 0.3s;
         border-radius: 5px;
         float: left;
         margin-left: 12px;
         margin-right: 12px;
    }
    
    .item__root:hover {
       box-shadow: 0 8px 16px 0 rgba(0,0,0,0.2);
    }
    
  4. 更新产品名称以显示在Teaser底部,并修改文本颜色。

    code language-css
    .item__name {
        color: #000;
        display: block;
        float: left;
        font-size: 22px;
        font-weight: 900;
        line-height: 1em;
        padding: 0.75em;
        text-transform: uppercase;
        width: 75%;
    }
    
  5. 更新产品的价格以使其也显示在Teaser的底部,并修改文本颜色。

    code language-css
    .price {
        color: #000;
        display: block;
        float: left;
        font-size: 18px;
        font-weight: 900;
        padding: 0.75em;
        padding-bottom: 2em;
        width: 25%;
    
        ...
    
  6. 更新底部的媒体查询,以使您可以在小于的屏幕中栈叠名称和价格 992像素.

    code language-css
    @media (max-width: 992px) {
        .productteaser .item__name {
            font-size: 18px;
            width: 100%;
        }
        .productteaser .item__price {
            font-size: 14px;
            width: 100%;
        }
    }
    

    此时,您应该会看到卡样式反映在webpack-dev-server中:

    Webpack开发服务器Teaser更改

    但是,这些更改尚未部署到AEM。 您可以下载 此处为解决方案文件.

  7. 使用您的Maven技能从命令行终端将更新部署到AEM:

    code language-shell
    $ cd aem-cif-guides-venia/
    $ mvn clean install -PautoInstallPackage,cloud
    
    note note
    NOTE
    此外, IDE设置和工具 可以直接将项目文件同步到本地AEM实例,而无需执行完整的Maven构建。

查看更新的产品Teaser view-updated-product-teaser

在将项目的代码部署到AEM后,您现在应该能够查看产品Teaser的更改。

  1. 返回浏览器并刷新主页: http://localhost:4502/editor.html/content/venia/us/en.html. 您应该会看到应用的已更新产品Teaser样式。

    更新了产品Teaser样式

  2. 通过添加其他产品Teaser进行试验。 使用布局模式更改组件的宽度和偏移,以便在一行中显示多个Teaser。

    多个产品Teaser

疑难解答 troubleshooting

您可以在中验证 CRXDE-Lite 已部署更新的CSS文件: http://localhost:4502/crx/de/index.jsp#/apps/venia/clientlibs/clientlib-site/css/site.css

在部署新的CSS文件和/或JavaScript文件时,确保浏览器不会提供过时文件也很重要。 您可以通过清除浏览器缓存或启动新的浏览器会话来消除此潜在问题。

AEM还会尝试缓存客户端库以提高性能。 有时,在代码部署后,会提供旧文件。 您可以使用手动使AEM客户端库缓存失效 重建客户端库工具. 如果您怀疑AEM缓存了旧版本的客户端库,首选方法是使缓存无效。 重建库效率低下且耗时。

恭喜 congratulations

您完成了第一个AEM CIF核心组件的样式设计,并且使用了webpack开发服务器!

奖励质询 bonus-challenge

使用 AEM样式系统 创建两个可由内容作者切换的样式。 用样式系统进行开发 包括有关如何完成此任务的详细步骤和信息。

附加挑战 — 样式系统

其他资源 additional-resources

recommendation-more-help
fbcff2a9-b6fe-4574-b04a-21e75df764ab