我的代码中有这个div。
<div ng-class="className" >{{className}}</div>
在某些时候,我通过ng-click调用changeClass
函数来更改此div的类。
$scope.changeClass = function(){
console.log($scope.className)
if ($scope.className === "expand-icon")
$scope.className = "expand-icon.expanded";
else
$scope.className = "expand-icon";
};
我可以看到类更改因为console.log而且{{className}}在页面上输出了。然而,css类似乎没有被应用。
实际上它是&#39; +&#39;需要变成&#39; - &#39;用动画。这是css: /* + button */
.expand-icon {
height: 32px;
width: 32px;
position: relative;
}
.expand-icon::before, .expand-icon::after {
content: " ";
width: 32px;
height: 6px;
background-color: #fff;
display: block;
position: absolute;
top: 50%;
left: 50%;
transition: all 0.15s cubic-bezier(.42, 0, .58, 1);
opacity: 1;
border-radius: 2px;
}
.expand-icon::before {
transform: translate(-50%, -50%) rotate(90deg);
}
.expand-icon::after {
transform: translate(-50%, -50%);
}
.expand-icon {
height: 32px;
width: 32px;
position: relative;
}
.expand-icon.expanded::before {
transform: translate(-50%, -50%) rotate(0deg);
}
.expand-icon.expanded::after {
transform: translate(-50%, -50%) rotate(-90deg);
opacity: 0;
}
所以应用了expand-icon但是expand-icon.expanded没有任何影响,因为我使用了这个ng-class技巧。知道为什么吗?
答案 0 :(得分:3)
您应该用空格替换点:$scope.className = "expand-icon expanded";
或者更好,请使用ng-class
:
// probably rename it to something like $scope.toggleExpanded()
$scope.changeClass = function(){
$scope.expanded = !$scope.expanded;
};
在你的HTML中:
<div class="expand-icon"
ng-class="{ expanded: expanded }">{{className}}</div>
这将始终适用于您的expand-icon
课程,仅在expanded
属性真实时适用$scope.expanded
课程。
答案 1 :(得分:0)
ng-class="className"
用于表达。例如:ng-class="{classNam:true}"
。
在这种情况下,你可以这样做:class="{{className}}"
答案 2 :(得分:0)
试试这个
<div class="{{className}}">{{className}}</div>