AngularJS에서 조건부 클래스 애플리케이션 구현
문제:
AngularJS 애플리케이션 렌더링을 구상합니다. 특정 인덱스에 요소가 있는 정렬되지 않은 목록의 배열 사용자 정의 클래스를 표시해야 합니다. 이를 효율적으로 달성할 수 있는 방법은 무엇입니까?
해결책:
조건에 따라 클래스를 동적으로 적용하려면 다음과 같은 몇 가지 접근 방식이 있습니다.
다음과 함께 표현식 사용 ngClass:
<li ng:class="{true: 'selected', false: ''}[$index == selectedIndex]">...</li>
이 고전적인 접근 방식은 부울 값으로 직접 평가하여 인덱스가 selectedIndex 속성과 일치하는 경우 "selected" 클래스를 할당합니다.
객체 표현식 사용 ngClass:
<li ng-class="{selected: $index == selectedIndex}">...</li>
AngularJS는 이제 객체 표현식을 기반으로 클래스 할당을 허용합니다. 각 속성 이름은 클래스를 나타내며 해당 값은 클래스의 존재 여부를 결정합니다.
모델 속성을 클래스에 매핑:
<li ng-class="{admin: 'enabled', moderator: 'disabled', '': 'hidden'}[user.role]">...</li>
이 고급 접근 방식은 모델 속성을 클래스 이름에 매핑하여 특정 조건에 의존하지 않고 클래스를 할당할 수 있는 유연성을 제공합니다. ngIf/ngHide.
접근 방식 선택은 코드 구조 및 유지 관리에 대한 특정 요구 사항과 선호도에 따라 다르다는 점을 기억하세요.
위 내용은 AngularJS 목록에서 조건부 클래스를 효율적으로 적용하려면 어떻게 해야 합니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!