AngularJS / HAML: добавить класс CSS, если свойство имеет значение true
Я работаю над настройкой элемента директивы ItemSelector, данные ItemSelector поступают с сервера rails.
вот код хамла:
.directive-items-selector{ ng_click: "openItemsSelector( $event )" }
.wrapper
%ui_select.ui-select{ ng: { model: "input.model", disabled: "disabled",
change: "itemSelectModelChanged()" },
search_enabled: "{{ options.searchable }}" }
%ui_select_match.ui-select-match{ items_selector_match: '',
placeholder: "{{ input.placeholder }}",
allow_clear: "{{ options.clearable }}",
title: "{{ $select.selected.label }}" }
%i.fa{ ng_class: 'icon' }
{{ $select.selected.label }}
%i.archived.fa.fa-archive{ ng_if: '$select.selected.object.is_archived' }
%span.archived{ translate: 'archived.yes' }
%ui_select_choices.ui-select-choices{ repeat: "item.id as item in input.filteredItems track by item.id",
refresh: "reloadItems( $select.search )",
refresh_delay: '{{ input.filterDelay }}' }
.item{ ng_attr_title: "{{ ::item.label }}" }
.item-label {{ ::item.label }}
%small.item-details {{ ::item.details }}
.items-selector-actions
%a.pointer.action{ ng: { if: 'linkToModal', click: 'openDetails()', disabled: "!model" }}
{{ 'btn.details' | translate }}
%a.pointer.action{ ng: { if: 'createButton && klassName && !disabled', click: 'createItem()' }}
{{ 'btn.new' | translate }}
Я проверяю, заархивирован ли выбранный объект или нет:
$select.selected.object.is_archived
на данный момент я добавляю значок и небольшой текст, чтобы сообщить пользователю, что этот выбранный объект заархивирован, что я хочу изменить, и добавитьтекстовое оформление: line-through red; быть таким:
Как добавить класс CSS зависит от значения $select.selected.object.is_archived
1 ответ
Ng-класс принимает объект, где ключ - это ваш класс, а значение - условие, когда он должен применяться:
ng-class="{'desiredClass': $select.selected.object.is_archived}"
Или другое решение использует троичный оператор:
ng-class="$select.selected.object.is_archived ? 'desiredClass' : ''"
В HAML, используя различные способы:
%div{'ng-class': "{'desiredClass': condition === true}"}
%div{'ng_class': "{'desiredClass': condition === true}"}
%div{'ng': {'class': "{'desiredClass': condition === true}"}}
Вот рабочий пример кода: https://codepen.io/anon/pen/pKreGv?editors=1010