AEM 스타일 시스템에서 사용되는 BEM-유사한 규칙을 이해하려면 스타일 시스템에 대한 코드 방법 이해에서 컨텐츠를 검토하십시오.
AEM 스타일 시스템에 대해 구현되는 두 가지 기본 방식이나 스타일이 있습니다.
레이아웃 스타일은 구성 요소의 많은 요소에 영향을 주어 구성 요소의 정의 및 식별 가능한 표현물(디자인 및 레이아웃)을 작성하는 데, 종종 특정 재사용 가능한 브랜드 개념에 맞춰 정렬됩니다. 예를 들어 티저 구성 요소는 기존 카드 기반 레이아웃, 가로 프로모션 스타일 또는 이미지에 텍스트를 오버레이하는 영웅 레이아웃으로 표시할 수 있습니다.
디스플레이 스타일 은 레이아웃 스타일의 작은 변형에 영향을 주는 데 사용되지만 레이아웃 스타일의 기본 특성이나 의도는 변경되지 않습니다. 예를 들어, 히어로 레이아웃 스타일에는 색상 구성표를 기본 브랜드 색상 구성표에서 보조 브랜드 색상 구성표로 변경하는 표시 스타일이 있을 수 있습니다.
AEM 작성자가 사용할 수 있는 스타일 이름을 정의할 때 다음을 수행하는 것이 가장 좋습니다.
AEM 작성자가 사용할 수 있는 가능한 스타일 조합 수가 증가하면 브랜드 표준에 대해 QA와 유효성이 검사되어야 하는 순열이 더 많이 존재합니다. 너무 많은 옵션을 사용하면 원하는 효과를 만드는 데 필요한 선택 사항이나 조합이 불분명해질 수 있으므로 작성자를 혼동시킬 수도 있습니다.
스타일 이름 또는 AEM 작성자에게 제공되는 옵션과 구현 CSS 클래스 이름은 AEM에서 분리됩니다.
이를 통해 스타일 옵션을 AEM 작성자가 명확하게 알고 이해할 수 있는 어휘로 레이블 지정할 수 있지만, 이를 통해 CSS 개발자는 향후 방증, 의미 있는 방식으로 CSS 클래스의 이름을 지정할 수 있습니다. 예:
구성 요소에는 브랜드의 기본 및 보조 색상으로 색상을 지정할 수 있는 옵션이 있어야 하지만, AEM 작성자는 기본 및 보조 디자인 언어가 아니라 녹색 및 노란색으로 색상을 알고 있습니다.
AEM 스타일 시스템에서는 CSS 개발자가 .cmp-component--primary-color
및 .cmp-component--secondary-color
의 의미 체계 이름을 사용하여 CSS에서 실제 스타일 구현을 정의할 수 있도록 하면서 작성자에게 친숙한 레이블 녹색 및 노란색을 사용하여 이러한 색상 표시 스타일을 표시할 수 있습니다.
녹색의 스타일 이름이 .cmp-component--primary-color
에 매핑되고 노란색이 .cmp-component--secondary-color
에 매핑됩니다.
회사의 브랜드 색상이 차후에 변경되는 경우 변경해야 하는 모든 것은 .cmp-component--primary-color
및 .cmp-component--secondary-color
의 단일 구현과 스타일 이름입니다.
다음은 티저 구성 요소에 여러 가지 다른 레이아웃 및 표시 스타일을 지정할 수 있는 스타일 지정 사용 사례입니다.
이렇게 하면 스타일 이름(작성자에게 노출됨)과 관련 CSS 클래스가 구성되는 방식을 살펴봅니다.
다음 이미지는 사용 사례에 설명된 변형에 대한 티저 구성 요소에 대한 스타일 구성을 보여줍니다.
스타일 그룹 이름, 레이아웃 및 표시에 대해서는 이 문서에서 스타일 유형을 개념적으로 분류하는 데 사용되는 표시 스타일 및 레이아웃 스타일의 일반 개념과 일치합니다.
스타일 그룹 이름 및 스타일 그룹의 수는 구성 요소 사용 사례 및 프로젝트별 구성 요소 스타일 지정 규칙에 맞게 조정되어야 합니다.
예를 들어 Display 스타일 그룹 이름은 Colors로 지정되었을 수 있습니다.
아래 이미지는 스타일 메뉴 작성자가 상호 작용하여 구성 요소에 대한 적절한 스타일을 선택합니다. 스타일 이름과 스타일 그래픽 이름이 모두 작성자에게 표시됩니다.
기본 스타일은 종종 구성 요소의 가장 일반적으로 사용되는 스타일일 뿐만 아니라 페이지에 추가할 때 티저의 기본 스타일이 지정되지 않은 뷰입니다.
기본 스타일의 공통성에 따라 CSS는 .cmp-teaser
(수정자 없이) 또는 .cmp-teaser--default
에 직접 적용될 수 있습니다.
기본 스타일 규칙이 일부 변형에 적용되지 않는 것보다 더 자주 적용되는 경우 모든 변형이 암시적으로 상속되어야 하므로 .cmp-teaser
을 기본 스타일의 CSS 클래스로 사용하는 것이 가장 좋습니다. BEM 과 유사한 규칙이 수행된다고 가정할 경우 그렇지 않은 경우, .cmp-teaser--default
등의 기본 수정자를 통해 적용해야 하며, 이 수정자는 구성 요소의 스타일 구성의 기본 CSS 클래스 필드에 다시 추가해야 합니다. 그렇지 않으면 이러한 스타일 규칙이 각 변형에서 무시되어야 합니다.
"명명된" 스타일을 기본 스타일로 할당할 수도 있습니다(예: 아래에 정의된 히어로 스타일 (.cmp-teaser--hero)
). 그러나 .cmp-teaser
또는 .cmp-teaser--default
CSS 클래스 구현에 대해 기본 스타일을 구현하는 것이 더 명확합니다.
기본 레이아웃 스타일에 표시 스타일 이름이 없지만 작성자는 AEM 스타일 시스템 선택 도구에서 표시 옵션을 선택할 수 있습니다.
이는 우수 사례를 위반하는 것입니다.
효과가 있는 스타일 조합만 표시합니다.
작성자가 녹색의 표시 스타일을 선택하면 아무 일도 발생하지 않습니다.
이 사용 사례에서는 다른 모든 레이아웃 스타일이 브랜드 색상을 사용하여 색상을 사용할 수 있어야 하므로 이 위반을 인정합니다.
아래의 프로모션(오른쪽 정렬) 섹션에서 원하지 않는 스타일 조합을 방지하는 방법을 확인할 수 있습니다.
.cmp-teaser--promo
또는 .cmp-teaser--default
프로모션 레이아웃 스타일은 사이트에서 고부가가치 컨텐츠를 홍보하는 데 사용되며, 가로 방향으로 배치되어 웹 페이지에서 공간 대역을 가져오며, 검정색 텍스트를 사용하는 기본 프로모션 레이아웃 스타일로 브랜드 색상으로 스타일을 지정해야 합니다.
이를 위해서는 Promo의 레이아웃 스타일 및 Green 및 Yellow표시 스타일이 티저 구성 요소의 AEM 스타일 시스템에 구성되어 있습니다.
cmp-teaser--promo
.cmp-teaser--promo
cmp-teaser--promo
cmp-teaser--primary-color
cmp-teaser--promo.cmp-teaser--primary-color
cmp-teaser--promo
cmp-teaser--secondary-color
cmp-teaser--promo.cmp-teaser--secondary-color
프로모션 오른쪽 정렬 레이아웃 스타일은 이미지와 텍스트(오른쪽 이미지, 왼쪽 텍스트)의 위치를 변형하는 프로모션 스타일의 변형입니다.
오른쪽 맞춤은 해당 코어에서 디스플레이 스타일이며, 프로모션 레이아웃 스타일과 함께 선택한 디스플레이 스타일로 AEM 스타일 시스템에 입력할 수 있습니다. 이는 다음의 모범 사례를 위반합니다.
효과가 있는 스타일 조합만 표시합니다.
…기본 스타일에서 이미 위반되었습니다.
오른쪽 맞춤은 프로모션 레이아웃 스타일에만 영향을 주며 다른 두 레이아웃 스타일에는 영향을 주지 않으므로기본 및 주인공. 프로모션 레이아웃 스타일 컨텐츠를 마우스 오른쪽 단추로 정렬하는 CSS 클래스를 포함하는 새 레이아웃 스타일 프로모션(오른쪽 정렬)을 만들 수 있습니다.cmp -teaser--alternate
여러 스타일을 단일 스타일 항목으로 결합하면 사용 가능한 스타일과 스타일 순열의 수를 줄일 수 있으므로 최소한으로 하는 것이 가장 좋습니다.
CSS 클래스 이름 cmp-teaser--alternate
은 "오른쪽 정렬"의 작성자에게 친숙한 명명식과 일치하지 않아도 됩니다.
cmp-teaser--promo cmp-teaser--alternate
.cmp-teaser--promo.cmp-teaser--alternate
cmp-teaser--promo cmp-teaser--alternate
cmp-teaser--primary-color
.cmp-teaser--promo.cmp-teaser--alternate.cmp-teaser--primary-color
cmp-teaser--promo cmp-teaser--alternate
cmp-teaser--secondary-color
.cmp-teaser--promo.cmp-teaser--alternate.cmp-teaser--secondary-color
히어로 레이아웃 스타일은 구성 요소의 이미지를 제목과 링크가 겹쳐서 배경으로 표시합니다. 프로모션 레이아웃 스타일처럼 히어로 레이아웃 스타일은 브랜드 색상으로 표시될 수 있어야 합니다.
브랜드 색상으로 히어로 레이아웃 스타일에 색상을 지정하려면 프로모션 레이아웃 스타일에 사용된 것과 동일한 표시 스타일을 활용할 수 있습니다.
구성 요소별로 스타일 이름이 단일 CSS 클래스 세트에 매핑됩니다. 즉, 프로모션 레이아웃 스타일의 배경색을 지정하는 CSS 클래스 이름은 Hero 레이아웃 스타일의 텍스트와 링크에 색상을 지정해야 합니다.
그러나 CSS 규칙을 범위 지정함으로써 세밀하게 달성할 수 있지만, 이렇게 하려면 CSS 개발자가 이러한 순열을 AEM에서 제정하는 방법을 이해해야 합니다.
Promote 레이아웃 스타일의 배경색을 기본(녹색) 색상으로 표시하는 CSS입니다.
.cmp-teaser--promo.cmp-teaser--primary--color {
...
background-color: green;
...
}
기본(녹색) 색상으로 Hero 레이아웃 스타일의 텍스트를 색상을 지정하는 CSS:
.cmp-teaser--hero.cmp-teaser--primary--color {
...
color: green;
...
}
cmp-teaser--hero
.cmp-teaser--hero
cmp-teaser--hero
cmp-teaser--primary-color
cmp-teaser--hero.cmp-teaser--primary-color
cmp-teaser--hero
cmp-teaser--secondary-color
cmp-teaser--hero.cmp-teaser--secondary-color