Я пытаюсь переключить класс элемента с помощью ng-class
<button class="btn">
<i ng-class="{(isAutoScroll()) ? 'icon-autoscroll' : 'icon-autoscroll-disabled'}"></i>
</button>
isAutoScroll ():
$scope.isAutoScroll = function()
{
$scope.autoScroll = ($scope.autoScroll) ? false : true;
return $scope.autoScroll;
}
По сути, если $scope.autoScroll
true, я хочу, чтобы ng-class был, icon-autoscroll
а если false, я хочу, чтобы он былicon-autoscroll-disabled
То, что у меня сейчас не работает и выдает эту ошибку в консоли
Error: Lexer Error: Unexpected next character at columns 18-18 [?] in expression [{(isAutoScroll()) ? 'icon-autoscroll' : 'icon-autoscroll-disabled'}].
Как мне правильно сделать это?
РЕДАКТИРОВАТЬ
Решение 1: (устарело)
<button class="btn" ng-click="autoScroll = !autoScroll">
<i ng-class="{'icon-autoscroll': autoScroll, 'icon-autoscroll-disabled': !autoScroll}"></i>
</button>
РЕДАКТИРОВАТЬ 2
Решение 2:
Я хотел обновить решение, так как оно было Solution 3
предоставлено Стьюи. Он является самым стандартным, когда дело доходит до троичного оператора (и мне легче всего читать). Решение будет
<button class="btn" ng-click="autoScroll = !autoScroll">
<i ng-class="autoScroll ? 'icon-autoscroll' : 'icon-autoscroll-disabled'"></i>
</button>
переводится как:
if (autoScroll == true) ?
// использовать класс 'icon-autoscroll' :
// еще использовать'icon-autoscroll-disabled'
autoScroll
здесь будет просто эффект в каждой кнопке? (Я протестировал это с несколькими кнопками, и это тоже хорошо работает) Я имею в виду, когда я нажимаю каждую кнопку, это влияет только на эту кнопку, а не на все кнопки.
angular expressions
per docs => Нет выражений потока управления: вы не можете выполнять одно из следующих действий в угловом выражении: условные выражения, циклы или бросок. Используйте другую функцию или директиву