我正在尝试使用切换元素的类 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
是真的,我希望 ng-class 是icon-autoscroll
,如果它是假的,我希望它是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
应该使用 Stewie 提供的解决方案。当涉及到三元运算符时,它是最标准的(对我来说也是最容易阅读的)。解决办法是
<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'